/* Iranmehr — bilingual diaspora directory. LTR default; RTL under [dir=rtl]. */

:root {
    --navy:        #0f2557;
    --navy-light:  #1c3a7a;
    --navy-mid:    #2b4f9e;
    --saffron:     #d49a3a;
    --saffron-dark:#b67f27;
    --ink:         #17233b;
    --gray:        #5b6472;
    --line:        #e4e7ee;
    --bg:          #f6f7f9;
    --bg-card:     #ffffff;
    --radius:      12px;
    --shadow:      0 1px 3px rgba(16,32,64,.08), 0 6px 18px rgba(16,32,64,.05);
    --font-en:     "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    --font-fa:     "Vazirmatn", Tahoma, system-ui, sans-serif;
    --maxw:        1120px;
}

/* Self-hosted subsets (fontsource). Inter = latin (EN); Vazirmatn = arabic
   (Persian) + latin, split by unicode-range. Weights: 400/500/600/700/800. */
@font-face { font-family:"Inter"; font-weight:400; font-display:swap; src:url("/fonts/webfonts/inter-latin-400-normal.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-weight:500; font-display:swap; src:url("/fonts/webfonts/inter-latin-500-normal.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-weight:600; font-display:swap; src:url("/fonts/webfonts/inter-latin-600-normal.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-weight:700; font-display:swap; src:url("/fonts/webfonts/inter-latin-700-normal.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-weight:800; font-display:swap; src:url("/fonts/webfonts/inter-latin-800-normal.woff2") format("woff2"); }

/* Vazirmatn — Arabic/Persian glyphs. */
@font-face { font-family:"Vazirmatn"; font-weight:400; font-display:swap; unicode-range:U+0600-06FF,U+0750-077F,U+08A0-08FF,U+200C-200E,U+2010-2011,U+FB50-FDFF,U+FE70-FEFF; src:url("/fonts/webfonts/vazirmatn-arabic-400-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:500; font-display:swap; unicode-range:U+0600-06FF,U+0750-077F,U+08A0-08FF,U+200C-200E,U+2010-2011,U+FB50-FDFF,U+FE70-FEFF; src:url("/fonts/webfonts/vazirmatn-arabic-500-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:600; font-display:swap; unicode-range:U+0600-06FF,U+0750-077F,U+08A0-08FF,U+200C-200E,U+2010-2011,U+FB50-FDFF,U+FE70-FEFF; src:url("/fonts/webfonts/vazirmatn-arabic-600-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:700; font-display:swap; unicode-range:U+0600-06FF,U+0750-077F,U+08A0-08FF,U+200C-200E,U+2010-2011,U+FB50-FDFF,U+FE70-FEFF; src:url("/fonts/webfonts/vazirmatn-arabic-700-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:800; font-display:swap; unicode-range:U+0600-06FF,U+0750-077F,U+08A0-08FF,U+200C-200E,U+2010-2011,U+FB50-FDFF,U+FE70-FEFF; src:url("/fonts/webfonts/vazirmatn-arabic-800-normal.woff2") format("woff2"); }

/* Vazirmatn — Latin glyphs (mixed content on Persian pages). */
@font-face { font-family:"Vazirmatn"; font-weight:400; font-display:swap; unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+2215; src:url("/fonts/webfonts/vazirmatn-latin-400-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:500; font-display:swap; unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+2215; src:url("/fonts/webfonts/vazirmatn-latin-500-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:600; font-display:swap; unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+2215; src:url("/fonts/webfonts/vazirmatn-latin-600-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:700; font-display:swap; unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+2215; src:url("/fonts/webfonts/vazirmatn-latin-700-normal.woff2") format("woff2"); }
@font-face { font-family:"Vazirmatn"; font-weight:800; font-display:swap; unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+2215; src:url("/fonts/webfonts/vazirmatn-latin-800-normal.woff2") format("woff2"); }

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0; background: var(--bg); color: var(--ink);
    font-family: var(--font-en); line-height: 1.6; font-size: 17px;
}
body.lang-fa { font-family: var(--font-fa); }
[dir="rtl"] { text-align: right; }

img { max-width: 100%; height: auto; }
a { color: var(--navy-mid); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { color: var(--navy); line-height: 1.25; margin: 0 0 .6em; }
h1 { font-size: clamp(1.7rem, 4vw, 2.4rem); }
h2 { font-size: clamp(1.3rem, 3vw, 1.7rem); margin-top: 1.6em; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 1.2rem; }
.container.narrow { max-width: 760px; }
.text-center { text-align: center; }
.muted { color: var(--gray); }
.lead { font-size: 1.12rem; color: var(--gray); margin: 0 0 1.4rem; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); border:0; }
.skip-link { position:absolute; left:-999px; top:0; background:var(--navy); color:#fff; padding:.5rem 1rem; z-index:100; }
.skip-link:focus { left:0; }

/* Buttons */
.btn { display:inline-block; padding:.6rem 1.1rem; border-radius:8px; font-weight:600;
    border:1px solid transparent; cursor:pointer; font-size:.98rem; transition:.15s; }
.btn:hover { text-decoration:none; }
.btn-primary { background:var(--saffron); color:#3a2905; border-color:var(--saffron-dark); }
.btn-primary:hover { background:var(--saffron-dark); color:#fff; }
.btn-ghost { background:transparent; color:var(--navy); border-color:var(--line); }
.btn-ghost:hover { background:var(--navy); color:#fff; }
.btn-full { display:block; width:100%; text-align:center; }
.btn-sm { padding:.35rem .7rem; font-size:.85rem; }

/* Header — frosted glass so the navy wordmark reads with no chip/box. */
.site-header { position:sticky; top:0; z-index:50; color:var(--navy);
    background:rgba(255,255,255,.72);
    -webkit-backdrop-filter:saturate(180%) blur(14px);
    backdrop-filter:saturate(180%) blur(14px);
    border-bottom:1px solid rgba(15,37,87,.10); }
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.5rem 1.2rem; }
.brand { display:flex; align-items:center; gap:.7rem; color:var(--navy); }
.brand:hover { text-decoration:none; }
/* Legacy wordmark at its native 211×50 — do not resize or box it. */
.brand-logo { display:block; width:211px; height:50px; }
.brand-since { font-family:var(--font-en); font-size:.62rem; font-weight:600; color:var(--gray); letter-spacing:.05em; text-transform:uppercase; }
/* Footer still uses a text mark (correct Persian spelling). */
.brand-mark { font-family:var(--font-fa); font-size:1.5rem; font-weight:700; color:var(--saffron); }
.site-nav { display:flex; align-items:center; gap:1.1rem; }
.site-nav a { color:var(--navy); font-size:.95rem; font-weight:500; }
.site-nav a:hover, .site-nav a.active { color:var(--navy); text-decoration:none; }
.site-nav a.active { border-bottom:2px solid var(--saffron); }
.lang-switch { background:rgba(15,37,87,.08); color:var(--navy); padding:.3rem .7rem; border-radius:6px; }
.lang-switch:hover { background:rgba(15,37,87,.14); }
.nav-toggle { display:none; background:none; border:0; color:var(--navy); font-size:1.5rem; cursor:pointer; }

/* Hero */
.hero { background:linear-gradient(135deg,var(--navy),var(--navy-mid)); color:#fff; padding:3rem 0 3.4rem; }
.hero h1 { color:#fff; margin:.2em 0; }
.hero-eyebrow { color:var(--saffron); font-weight:600; letter-spacing:.03em; margin:0 0 .3rem; }
.hero-sub { color:#d5def2; font-size:1.15rem; margin:0 0 1.6rem; }
.hero-search { display:flex; gap:.5rem; max-width:560px; }
.hero-search input { flex:1; padding:.8rem 1rem; border:0; border-radius:8px; font-size:1rem; }

/* Grids */
.category-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:1rem; }
.category-tile { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius);
    padding:1.2rem; display:flex; flex-direction:column; gap:.35rem; box-shadow:var(--shadow); transition:.15s; }
.category-tile:hover { transform:translateY(-2px); border-color:var(--saffron); text-decoration:none; }
.cat-emoji { font-size:1.9rem; }
.cat-name { font-weight:700; color:var(--navy); font-size:1.05rem; }
.cat-desc { color:var(--gray); font-size:.9rem; }
.cat-count { align-self:flex-start; background:var(--navy); color:#fff; font-size:.75rem; padding:.1rem .5rem; border-radius:20px; }

.city-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:.9rem; }
.city-tile { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius);
    padding:1rem 1.1rem; display:flex; flex-direction:column; gap:.2rem; box-shadow:var(--shadow); }
.city-tile:hover { border-color:var(--saffron); text-decoration:none; }
.city-name { font-weight:700; color:var(--navy); }
.city-region { color:var(--gray); font-size:.85rem; }
.city-blurb { color:var(--gray); font-size:.85rem; margin-top:.3rem; }

/* Content + sidebar */
.content-with-sidebar { display:grid; grid-template-columns:1fr 300px; gap:2.5rem; align-items:start; margin:1.5rem 0 3rem; }
.content-sidebar { position:sticky; top:82px; display:flex; flex-direction:column; gap:1rem; }
.sidebar-card { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius); padding:1rem; box-shadow:var(--shadow); }
.sidebar-card h3 { font-size:1rem; margin:0 0 .6rem; }
.sidebar-cats { list-style:none; margin:0; padding:0; }
.sidebar-cats li { margin:.15rem 0; }
.sidebar-advertise { background:var(--navy); color:#fff; }
.sidebar-advertise h3, .sidebar-advertise p { color:#fff; }
.site-search { display:flex; gap:.4rem; }
.site-search input { flex:1; padding:.5rem .7rem; border:1px solid var(--line); border-radius:6px; }

/* Listings */
.listing-grid { display:flex; flex-direction:column; gap:1rem; margin:1rem 0; }
.listing-card { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius); padding:1.1rem 1.2rem; box-shadow:var(--shadow); }
.listing-card.featured { border-color:var(--saffron); border-inline-start:4px solid var(--saffron); }
.lc-head { display:flex; align-items:center; justify-content:space-between; gap:.6rem; }
.lc-head h3 { margin:0; font-size:1.15rem; }
.lc-meta { color:var(--gray); font-size:.9rem; margin:.3rem 0; display:flex; flex-wrap:wrap; gap:.8rem; }
.lc-desc { margin:.4rem 0 .7rem; }
.lc-actions { display:flex; gap:.5rem; flex-wrap:wrap; }
.badge { font-size:.72rem; font-weight:700; padding:.15rem .55rem; border-radius:20px; text-transform:uppercase; letter-spacing:.03em; }
.badge-featured { background:var(--saffron); color:#3a2905; }

.listing-header { display:flex; align-items:center; gap:.8rem; }
.listing-tags { display:flex; gap:.8rem; flex-wrap:wrap; margin:0 0 1rem; }
.listing-facts { display:grid; grid-template-columns:auto 1fr; gap:.4rem 1rem; margin:1.2rem 0; }
.listing-facts dt { font-weight:600; color:var(--navy); }
.listing-facts dd { margin:0; }
.claim-box { background:#fff8ec; border:1px solid #f0dcae; border-radius:var(--radius); padding:1rem 1.2rem; margin-top:1.5rem; }

/* Empty state / notices */
.empty-state { background:var(--bg-card); border:1px dashed var(--line); border-radius:var(--radius); padding:1.6rem; text-align:center; }
.notice { padding:.8rem 1rem; border-radius:8px; margin:1rem 0; }
.notice-ok { background:#e6f7ec; border:1px solid #b7e4c7; color:#1c6b3a; }

/* Pills / interlinks */
.pill-links { list-style:none; display:flex; flex-wrap:wrap; gap:.5rem; padding:0; margin:.6rem 0 1.6rem; }
.pill-links a { background:var(--bg-card); border:1px solid var(--line); border-radius:20px; padding:.3rem .8rem; font-size:.88rem; display:inline-block; }
.pill-links a:hover { border-color:var(--saffron); text-decoration:none; }
.interlinks { margin-top:2rem; }

/* FAQ */
.faq { margin:2rem 0; }
.faq-item { background:var(--bg-card); border:1px solid var(--line); border-radius:8px; margin:.5rem 0; padding:.2rem .3rem; }
.faq-item summary { cursor:pointer; font-weight:600; padding:.7rem .8rem; color:var(--navy); }
.faq-a { padding:0 .8rem .8rem; color:var(--gray); }

/* Forms */
.stack-form, .lead-form { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem; box-shadow:var(--shadow); }
.form-group { margin-bottom:.9rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group label { display:block; font-weight:600; font-size:.9rem; margin-bottom:.3rem; }
.form-group input, .form-group select, .form-group textarea {
    width:100%; padding:.6rem .7rem; border:1px solid var(--line); border-radius:7px; font:inherit; }
.form-privacy { font-size:.82rem; color:var(--gray); margin:.7rem 0 0; }
.lead-cta { background:#fff8ec; border:1px solid #f0dcae; border-radius:var(--radius); padding:1.4rem; margin:2rem 0; }

/* Pricing */
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.2rem; margin:1.5rem 0; }
.price-card { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; text-align:center; box-shadow:var(--shadow); }
.price-card-highlight { border-color:var(--saffron); border-width:2px; }
.price { font-size:1.8rem; font-weight:800; color:var(--navy); margin:.4rem 0; }
.price-blurb { color:var(--gray); min-height:3em; }

/* Hafez */
.hafez-stage { text-align:center; margin:1.5rem 0; }
.hafez-stage img { border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); background:#fff; padding:.5rem; }

/* Home extras */
.home-section { margin:2.4rem 0; }
.home-cta { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; margin:2.4rem 0 3rem; }
.cta-card { background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; box-shadow:var(--shadow); }

/* AdSense fixed slots */
.ad-slot { margin:1.5rem 0; min-height:90px; text-align:center; overflow:hidden; }
.ad-slot .ad-label { display:block; font-size:.65rem; letter-spacing:.08em; text-transform:uppercase; color:var(--gray); opacity:.6; margin-bottom:.3rem; }
.sidebar-card + .ad-slot, .content-sidebar .ad-slot { margin-top:1rem; }

/* Breadcrumbs */
.breadcrumbs { font-size:.85rem; color:var(--gray); margin:1rem 0; }
.breadcrumbs a { color:var(--gray); }

/* Footer */
.site-footer { background:var(--navy); color:#c9d4ea; margin-top:3rem; padding:2.4rem 0 1.4rem; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:1.6rem; }
.footer-col h4 { color:#fff; font-size:.95rem; margin:0 0 .6rem; }
.footer-col ul { list-style:none; margin:0; padding:0; }
.footer-col li { margin:.25rem 0; }
.footer-col a { color:#c9d4ea; font-size:.9rem; }
.footer-brand .brand-mark { color:var(--saffron); font-size:1.6rem; }
.footer-since { font-size:.82rem; color:#9fb0d0; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:1.6rem; padding-top:1rem; font-size:.82rem; color:#9fb0d0; }

/* RTL adjustments */
[dir="rtl"] .site-nav a.active { border-bottom:2px solid var(--saffron); }
[dir="rtl"] .listing-card.featured { border-inline-start:4px solid var(--saffron); }
[dir="rtl"] .brand-name { font-family:var(--font-fa); }

/* Responsive */
@media (max-width: 900px) {
    .content-with-sidebar { grid-template-columns:1fr; }
    .content-sidebar { display:none; }
    .footer-grid { grid-template-columns:1fr 1fr; }
    .home-cta { grid-template-columns:1fr; }
    .nav-toggle { display:block; }
    .site-nav { display:none; position:absolute; top:100%; inset-inline-start:0; inset-inline-end:0;
        background:rgba(255,255,255,.94);
        -webkit-backdrop-filter:saturate(180%) blur(14px);
        backdrop-filter:saturate(180%) blur(14px);
        border-bottom:1px solid rgba(15,37,87,.10); box-shadow:0 10px 22px rgba(15,37,87,.10);
        flex-direction:column; align-items:flex-start; padding:1rem 1.2rem; gap:.8rem; }
    .site-nav.open { display:flex; }
}
@media (max-width: 560px) {
    .form-row { grid-template-columns:1fr; }
    .footer-grid { grid-template-columns:1fr; }
    .hero-search { flex-direction:column; }
}
