/* ══════════════════════════════════════════════════════════════════════
   PUBLIC WEBSITE — MASTER DESIGN SYSTEM
   Sky High Realty NYC — Glassmorphic + Modern
   ══════════════════════════════════════════════════════════════════════ */

/* ── CSS Custom Properties ────────────────────────────────────────── */
:root {
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --color-primary: #3b82f6;
    --color-primary-dark: #2563eb;
    --color-primary-light: #60a5fa;
    --color-primary-bg: #dbeafe;
    --color-accent: #6366f1;
    --color-accent-dark: #4f46e5;
    --color-success: #10b981;
    --color-success-bg: #d1fae5;
    --color-warning: #f59e0b;
    --color-warning-bg: #fef3c7;
    --color-danger: #ef4444;
    --color-danger-bg: #fee2e2;
    --color-text: #111827;
    --color-text-secondary: #374151;
    --color-text-muted: #6b7280;
    --color-text-light: #9ca3af;
    --color-surface: #f9fafb;
    --color-border: #e5e7eb;
    --color-border-light: #f3f4f6;
    --glass-bg: rgba(255,255,255,0.95);
    --glass-border: rgba(255,255,255,0.5);
    --glass-blur: blur(20px);
    --shadow-sm: 0 4px 20px rgba(0,0,0,0.06);
    --shadow-md: 0 8px 32px rgba(0,0,0,0.06);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.12);
    --shadow-btn: 0 4px 14px rgba(59,130,246,0.35);
    --shadow-btn-hover: 0 6px 20px rgba(59,130,246,0.45);
    --radius-sm: 10px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-2xl: 24px;
    --radius-full: 9999px;
    --container-max: 1400px;
    --gutter: 28px;
    --navbar-height: 64px;
    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --duration-fast: 150ms;
    --duration-normal: 250ms;
    --duration-slow: 400ms;
}

/* ── Reset & Base ─────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
body {
    font-family: var(--font-body);
    color: var(--color-text);
    background: linear-gradient(145deg,#f0f2f5 0%,#e8ebf0 100%);
    line-height: 1.6;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4,h5,h6 {
    font-family: var(--font-body);
    font-weight: 800;
    color: var(--color-text);
    line-height: 1.25;
}
a { text-decoration:none; color:inherit; transition:all 0.2s; }
img { max-width:100%; display:block; }

@keyframes fadeInUp {
    from { opacity:0; transform:translateY(20px); }
    to { opacity:1; transform:translateY(0); }
}
@keyframes shimmer {
    0% { background-position: -468px 0; }
    100% { background-position: 468px 0; }
}
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.5;} }
@keyframes scaleIn { from{transform:scale(0.9);opacity:0;} to{transform:scale(1);opacity:1;} }

/* ── Layout ───────────────────────────────────────────────────────── */
.pub-page { min-height:100vh; }
.pub-container { max-width:var(--container-max); margin:0 auto; padding:0 var(--gutter); }

/* ── Glass Card ───────────────────────────────────────────────────── */
.glass-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

/* ══════════════════════════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════════════════════════ */
.pub-navbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255,255,255,0.5);
    transition: all 0.35s ease;
    box-shadow: 0 4px 30px rgba(0,0,0,0.04);
    height: var(--navbar-height);
}
.pub-navbar.scrolled {
    background: rgba(255,255,255,0.97);
    box-shadow: 0 4px 30px rgba(0,0,0,0.08);
    height: 56px;
}
.pub-navbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--gutter);
    height: 100%;
}
.pub-logo {
    font-size: 20px;
    font-weight: 800;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.pub-logo img { height: 34px; transition: height 0.3s; }
.pub-navbar.scrolled .pub-logo img { height: 28px; }

/* Nav Links */
.pub-nav-links {
    display: flex;
    align-items: center;
    gap: 4px;
    list-style: none;
}
.pub-nav-link {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-muted);
    padding: 8px 16px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s;
    white-space: nowrap;
}
.pub-nav-link:hover { color: var(--color-primary); background: var(--color-primary-bg); }
.pub-nav-link[data-active="true"] { color: var(--color-primary); background: var(--color-primary-bg); font-weight: 600; }
.pub-nav-link i { font-size: 16px; }

/* Mega Dropdown */
.pub-nav-has-dropdown { position: relative; }
.pub-nav-mega {
    position: absolute;
    top: calc(100% + 8px);
    left: -10px;
    min-width: 320px;
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: 16px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all 0.25s ease;
    z-index: 100;
    box-shadow: var(--shadow-md);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.pub-nav-has-dropdown:hover .pub-nav-mega { opacity:1; visibility:visible; transform:translateY(0); }
.pub-mega-heading { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-muted); padding:8px 14px 4px; }
.pub-nav-mega a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    font-size: 14px;
    color: var(--color-text-secondary);
    border-radius: 8px;
    transition: all 0.2s;
}
.pub-nav-mega a:hover { background:var(--color-primary-bg); color:var(--color-primary); }
.pub-nav-mega a i { font-size:16px; color:var(--color-text-muted); }
.pub-nav-mega a:hover i { color:var(--color-primary); }

/* Nav Actions */
.pub-nav-actions { display:flex; align-items:center; gap:8px; }

/* Inline Search */
.pub-nav-search { position:relative; display:flex; align-items:center; }
.pub-nav-search-toggle {
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    background: transparent; border: 1px solid var(--color-border); border-radius: var(--radius-sm);
    cursor: pointer; color: var(--color-text-muted); transition: all 0.2s;
    font-size: 16px;
}
.pub-nav-search-toggle:hover { border-color:var(--color-primary); color:var(--color-primary); background:var(--color-primary-bg); }
.pub-nav-search-form {
    position: absolute; right: 0; top: 50%; transform: translateY(-50%);
    width: 280px;
    transition: all 0.3s var(--ease-out-expo);
}
.pub-nav-search-form input {
    width: 100%; padding: 10px 14px; border: 2px solid var(--color-primary);
    border-radius: var(--radius-sm); font-size: 14px; font-family: var(--font-body);
    background: #fff; box-shadow: 0 4px 14px rgba(59,130,246,0.15);
    outline: none;
}

/* ── Buttons ──────────────────────────────────────────────────────── */
.pub-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 8px; padding: 10px 20px; font-family: var(--font-body);
    font-size: 14px; font-weight: 600; border: none; cursor: pointer;
    transition: all 0.2s; border-radius: var(--radius-md); line-height: 1.4;
    text-decoration: none;
}
.pub-btn-sm  { padding:8px 16px; font-size:13px; border-radius:var(--radius-sm); }
.pub-btn-lg  { padding:14px 28px; font-size:15px; }
.pub-btn-primary {
    background: linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);
    color: #fff; box-shadow: var(--shadow-btn);
}
.pub-btn-primary:hover { transform:translateY(-2px); box-shadow:var(--shadow-btn-hover); color:#fff; }
.pub-btn-secondary {
    background: var(--glass-bg); color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}
.pub-btn-secondary:hover { background:#fff; border-color:var(--color-primary); color:var(--color-primary); }
.pub-btn-outline {
    background: transparent; color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}
.pub-btn-outline:hover { border-color:var(--color-primary); color:var(--color-primary); background:var(--color-primary-bg); }
.pub-btn-success {
    background: linear-gradient(135deg,var(--color-success) 0%,#059669 100%);
    color: #fff; box-shadow: 0 4px 14px rgba(16,185,129,0.35);
}
.pub-btn-success:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(16,185,129,0.45); color:#fff; }
.pub-btn-white {
    background: #fff; color: var(--color-text); border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}
.pub-btn-white:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.pub-btn-icon {
    width: 40px; height: 40px; padding: 0; border-radius: var(--radius-sm);
    display: inline-flex; align-items: center; justify-content: center;
}

/* ── Cards ─────────────────────────────────────────────────────────── */
.pub-grid { display:grid; gap:24px; }
.pub-card {
    background: var(--glass-bg); backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl); box-shadow: var(--shadow-sm);
    overflow: hidden; transition: all 0.3s;
}
.pub-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.pub-card-img-container { position:relative; overflow:hidden; aspect-ratio:4/3; }
.pub-card-img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; }
.pub-card:hover .pub-card-img { transform:scale(1.05); }
.pub-card-content { padding:20px; }
.pub-card-title { font-size:17px; font-weight:700; margin-bottom:4px; color:var(--color-text); }
.pub-card-meta { font-size:13px; color:var(--color-text-muted); }

/* ── Forms ─────────────────────────────────────────────────────────── */
.pub-label {
    display:block; font-size:12px; font-weight:700; color:var(--color-text-muted);
    text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px;
}
.pub-input {
    width:100%; padding:10px 14px; border:1px solid var(--color-border);
    border-radius:var(--radius-sm); font-family:var(--font-body); font-size:14px;
    color:var(--color-text); background:#fff; transition:all 0.2s; -webkit-appearance:none;
}
.pub-input:focus { outline:none; border-color:var(--color-primary); box-shadow:0 0 0 3px rgba(59,130,246,0.15); }
.pub-input::placeholder { color:var(--color-text-light); }
select.pub-input {
    appearance:none; cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 12px center; padding-right:36px;
}
textarea.pub-input { resize:vertical; min-height:80px; }

/* ── Badges ────────────────────────────────────────────────────────── */
.pub-badge {
    display:inline-flex; align-items:center; padding:5px 12px;
    font-size:12px; font-weight:600; border-radius:var(--radius-full);
}
.pub-badge-primary { background:linear-gradient(135deg,var(--color-primary-bg),#bfdbfe); color:var(--color-primary-dark); }
.pub-badge-success { background:linear-gradient(135deg,var(--color-success-bg),#a7f3d0); color:#065f46; }
.pub-badge-warning { background:linear-gradient(135deg,var(--color-warning-bg),#fde68a); color:#92400e; }
.pub-badge-danger  { background:linear-gradient(135deg,var(--color-danger-bg),#fecaca); color:#991b1b; }
.pub-badge-new {
    background: linear-gradient(135deg,#f59e0b,#d97706); color:#fff;
    animation: pulse 2s infinite;
}

/* ── Pagination ────────────────────────────────────────────────────── */
.pub-pagination {
    display:flex; align-items:center; justify-content:center;
    gap:6px; margin-top:3rem;
}
.pub-pagination a,.pub-pagination span {
    display:flex; align-items:center; justify-content:center;
    min-width:40px; height:40px; font-size:14px; font-weight:500;
    color:var(--color-text-secondary); border:1px solid var(--color-border);
    border-radius:var(--radius-sm); transition:all 0.2s; background:#fff;
}
.pub-pagination a:hover { border-color:var(--color-primary); color:var(--color-primary); background:var(--color-primary-bg); }
.pub-pagination .active {
    background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));
    border-color:var(--color-primary); color:#fff;
}

/* ── Skeleton Loading ──────────────────────────────────────────────── */
.skeleton {
    background: linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
    background-size: 400% 100%;
    animation: shimmer 1.5s ease-in-out infinite;
    border-radius: var(--radius-sm);
}
.skeleton-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--color-border);
}
.skeleton-img { aspect-ratio: 4/3; background:#e5e7eb; }
.skeleton-text { height: 14px; margin: 12px 16px; border-radius: 4px; }
.skeleton-text-short { width: 60%; }
.skeleton-text-long { width: 90%; }

/* ── Footer ────────────────────────────────────────────────────────── */
.pub-footer {
    background: var(--glass-bg); backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-top: 1px solid var(--color-border); margin-top: 4rem;
}
.pub-footer-top {
    display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 3rem; padding: 48px 0 40px;
}
.pub-footer-brand p { color:var(--color-text-muted); font-size:14px; line-height:1.7; margin-top:12px; }
.pub-footer-heading { font-size:14px; font-weight:700; margin-bottom:20px; color:var(--color-text); }
.pub-footer-link {
    display:flex; align-items:center; gap:6px; margin-bottom:10px;
    color:var(--color-text-muted); font-size:14px; transition:all 0.2s;
}
.pub-footer-link:hover { color:var(--color-primary); }
.pub-footer-bottom {
    border-top:1px solid var(--color-border); padding:20px 0;
    text-align:center; color:var(--color-text-light); font-size:13px;
}
.pub-footer-social { display:flex; gap:8px; margin-top:16px; }
.pub-footer-social a {
    width:38px; height:38px; display:flex; align-items:center; justify-content:center;
    border:1px solid var(--color-border); border-radius:var(--radius-sm);
    color:var(--color-text-muted); transition:all 0.2s; font-size:16px;
}
.pub-footer-social a:hover { border-color:var(--color-primary); color:var(--color-primary); background:var(--color-primary-bg); }
.pub-footer-newsletter { margin-top: 20px; }
.pub-footer-newsletter p { font-size: 13px; color: var(--color-text-muted); margin-bottom: 8px; }
.pub-footer-newsletter-form { display: flex; gap: 8px; }
.pub-footer-newsletter-form input {
    flex: 1; padding: 8px 12px; border: 1px solid var(--color-border);
    border-radius: var(--radius-sm); font-size: 13px; font-family: var(--font-body);
    background: #fff;
}
.pub-footer-newsletter-form input:focus { outline: none; border-color: var(--color-primary); }

/* ── Scrollbar ─────────────────────────────────────────────────────── */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:#f5f5f5; }
::-webkit-scrollbar-thumb { background:#ccc; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:#999; }

/* ── Mobile Toggle & Drawer ────────────────────────────────────────── */
.pub-mobile-toggle {
    display:none; width:40px; height:40px; align-items:center; justify-content:center;
    background:transparent; cursor:pointer; border:1px solid var(--color-border);
    border-radius:var(--radius-sm); font-size: 20px; color: var(--color-text-muted);
}
.pub-drawer-backdrop {
    position:fixed; inset:0; background:rgba(0,0,0,0.4); z-index:1001;
}
.pub-drawer-panel {
    position:fixed; top:0; right:0; bottom:0; width:300px; max-width:85vw;
    background:#fff; z-index:1002; padding:20px;
    box-shadow:-4px 0 30px rgba(0,0,0,0.1);
    overflow-y:auto;
}
.pub-drawer-panel .pub-drawer-close {
    width:36px; height:36px; display:flex; align-items:center; justify-content:center;
    border:1px solid var(--color-border); border-radius:var(--radius-sm);
    background:transparent; cursor:pointer; margin-bottom:20px; margin-left:auto;
    font-size: 18px; color: var(--color-text-muted);
}
.pub-drawer-nav { list-style:none; }
.pub-drawer-nav a {
    display:flex; align-items:center; gap:10px; padding:14px 16px;
    font-size:15px; font-weight:500; color:var(--color-text-secondary);
    border-radius:var(--radius-sm); transition:all 0.2s;
}
.pub-drawer-nav a:hover { background:var(--color-primary-bg); color:var(--color-primary); }
.pub-drawer-nav a i { font-size:18px; }
.pub-drawer-divider { border:none; border-top:1px solid var(--color-border); margin:12px 0; }

/* ── Mobile Bottom Nav ─────────────────────────────────────────────── */
.pub-bottom-nav {
    display:none; position:fixed; bottom:0; left:0; right:0; z-index:999;
    background:rgba(255,255,255,0.95); backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    border-top:1px solid var(--color-border); height:56px;
    justify-content:space-around; align-items:center;
    box-shadow:0 -2px 20px rgba(0,0,0,0.06);
}
.pub-bottom-nav a {
    display:flex; flex-direction:column; align-items:center; gap:2px;
    color:var(--color-text-muted); font-size:10px; font-weight:600;
    transition:color 0.2s; padding:4px 12px; min-width:56px;
}
.pub-bottom-nav a i { font-size:20px; }
.pub-bottom-nav a:hover,.pub-bottom-nav a.active { color:var(--color-primary); }
.pub-bottom-nav .pub-bottom-badge {
    position:absolute; top:-2px; right:8px;
    width:16px; height:16px; border-radius:50%;
    background:var(--color-danger); color:#fff;
    font-size:9px; display:flex; align-items:center; justify-content:center;
}

/* ── Breadcrumbs ───────────────────────────────────────────────────── */
.pub-breadcrumbs { padding:12px 0; }
.pub-breadcrumbs ol,
.pub-breadcrumb {
    display:flex; align-items:center; flex-wrap:wrap; gap:0;
    list-style:none; margin:0; padding:0;
    font-size:13px; color:var(--color-text-muted);
}
.pub-breadcrumbs li,
.pub-breadcrumb-item {
    display:inline-flex; align-items:center;
}
.pub-breadcrumbs li:not(:last-child)::after,
.pub-breadcrumb-item:not(:last-child)::after {
    content:'\e930'; /* uil-angle-right-b */
    font-family:'unicons-line'; font-size:14px;
    color:var(--color-text-light); margin:0 6px;
}
.pub-breadcrumbs a,
.pub-breadcrumb-item a {
    color:var(--color-text-muted); text-decoration:none; transition:color 0.2s;
}
.pub-breadcrumbs a:hover,
.pub-breadcrumb-item a:hover {
    color:var(--color-primary); text-decoration:underline;
}
.pub-breadcrumbs li:last-child span,
.pub-breadcrumb-item.active,
.pub-breadcrumb-item[aria-current] {
    color:var(--color-text); font-weight:600;
}

/* ── Empty State ───────────────────────────────────────────────────── */
.pub-empty-state {
    text-align:center; padding:60px 20px;
}
.pub-empty-icon { font-size:64px; color:var(--color-text-light); margin-bottom:20px; }
.pub-empty-title { font-size:20px; font-weight:700; margin-bottom:8px; color:var(--color-text); }
.pub-empty-text { font-size:15px; color:var(--color-text-muted); margin-bottom:24px; max-width:400px; margin-left:auto; margin-right:auto; }
.pub-empty-suggestions { display:flex; flex-wrap:wrap; justify-content:center; gap:8px; }

/* ── Section Headers ───────────────────────────────────────────────── */
.pub-section { padding:60px 0; }
.pub-section-badge {
    display:inline-flex; align-items:center; gap:6px;
    background:var(--color-primary-bg); color:var(--color-primary-dark);
    padding:6px 16px; border-radius:var(--radius-full);
    font-size:12px; font-weight:700; text-transform:uppercase;
    letter-spacing:.05em; margin-bottom:12px;
}
.pub-section-title { font-size:32px; font-weight:800; margin-bottom:8px; }
.pub-section-subtitle { font-size:16px; color:var(--color-text-muted); max-width:560px; }

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width:1024px) {
    :root { --gutter:20px; }
    .pub-nav-links { display:none; }
    .pub-mobile-toggle { display:flex; }
    .pub-bottom-nav { display:flex; }
    .pub-footer-top { grid-template-columns:1fr 1fr; gap:2rem; }
    body { padding-bottom:56px; }
}
@media (max-width:640px) {
    :root { --gutter:16px; }
    .pub-footer-top { grid-template-columns:1fr; }
    .pub-section-title { font-size:24px; }
}

/* ── Print ──────────────────────────────────────────────────────────── */
@media print {
    .pub-navbar,.pub-footer,.pub-bottom-nav,.pub-mobile-toggle,
    .pub-drawer-backdrop,.pub-drawer-panel { display:none!important; }
    body { background:#fff; padding:0; }
    .pub-page { min-height:auto; }
}
