/* Peachy Photographers — design system (Design B · Clean Editorial, build-free) */
:root{
  --peach:#ff7a8a; --peach-deep:#e8476a; --peach-soft:#ffe7e6; --peach-soft2:#fff1ef;
  --plum:#2a1726; --ink:#3a2f37; --muted:#917f88;
  --cream:#fff8f4; --card:#ffffff; --line:#f0e2db; --line-2:#e7d4cc;
  --shadow:0 1px 2px rgba(42,23,38,.05),0 10px 24px rgba(42,23,38,.05);
  --shadow-lg:0 20px 48px rgba(42,23,38,.13);
  --radius:18px; --radius-sm:12px; --maxw:1120px;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);font-size:16px;line-height:1.65;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--peach-deep);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);color:var(--plum);line-height:1.12;margin:0 0 .5em;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.2vw,3.2rem)}
h2{font-size:clamp(1.5rem,3vw,2rem)}
h3{font-size:1.18rem}
p{margin:0 0 1rem}
.muted{color:var(--muted)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.4rem}
.section{padding:4rem 0}
.section--tight{padding:2rem 0}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.74rem 1.35rem;border-radius:999px;font-weight:600;font-size:.94rem;border:1px solid transparent;cursor:pointer;transition:.16s;text-decoration:none;font-family:var(--sans)}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--peach),var(--peach-deep));color:#fff;box-shadow:0 8px 20px rgba(232,71,106,.28)}
.btn-ghost{background:#fff;color:var(--plum);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--peach)}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-sm{padding:.46rem .9rem;font-size:.86rem}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,248,244,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:1.4rem;height:72px}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.25rem;color:var(--plum);letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand .dot{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--peach),var(--peach-deep));display:inline-block;box-shadow:0 2px 8px rgba(232,71,106,.4)}
.nav-links{display:flex;align-items:center;gap:1.4rem;margin-left:auto}
.nav-links a{color:var(--ink);font-weight:500;font-size:.94rem}
.nav-links a:hover{color:var(--peach-deep);text-decoration:none}
.nav-toggle{display:none;margin-left:auto;background:none;border:0;font-size:1.5rem;color:var(--plum);cursor:pointer}
@media(max-width:820px){
  .nav-links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:.5rem 1.4rem;box-shadow:var(--shadow);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:.8rem 0;width:100%;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin:.6rem 0}
  .nav-toggle{display:block}
}

/* ---------- Hero ---------- */
.hero{background:radial-gradient(900px 440px at 88% -12%,var(--peach-soft),transparent)}
.hero-inner{padding:4rem 0 3rem;max-width:720px}
.hero-split{display:grid;grid-template-columns:1fr .82fr;gap:3rem;align-items:center;padding:4.5rem 0 3.5rem}
.hero h1{margin-bottom:.6rem}
.hero h1 em{font-style:italic;color:var(--peach-deep)}
.hero .lede{font-size:1.14rem;color:var(--ink);opacity:.82;margin-bottom:1.7rem;max-width:40ch}
.eyebrow{display:inline-block;font-size:.76rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--peach-deep);background:var(--peach-soft);padding:.34rem .8rem;border-radius:999px;margin-bottom:1.1rem}
.hero-art{aspect-ratio:4/5;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,var(--peach-soft),#fbe9f2)}
.hero-art img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.hero-split{grid-template-columns:1fr;gap:1.8rem;padding-top:3rem}.hero-art{aspect-ratio:16/10;max-height:320px}}

/* ---------- Search bar ---------- */
.searchbar{display:flex;gap:.5rem;background:#fff;padding:.45rem;border-radius:999px;box-shadow:0 10px 30px rgba(42,23,38,.08);border:1px solid var(--line);max-width:480px}
.searchbar input,.searchbar select{border:0;background:none;font-size:1rem;padding:.62rem .85rem;flex:1;min-width:0;color:var(--ink);font-family:inherit}
.searchbar input:focus,.searchbar select:focus{outline:none}
.searchbar .btn{flex:0 0 auto}
@media(max-width:560px){.searchbar{flex-direction:column;border-radius:var(--radius)}.searchbar .btn{width:100%;justify-content:center}}

/* ---------- Stats strip ---------- */
.stats{display:flex;flex-wrap:wrap;gap:2.5rem;margin-top:2.2rem}
.stats .stat b{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--plum);font-weight:600}
.stats .stat span{font-size:.84rem;color:var(--muted)}

/* ---------- Grids ---------- */
.grid{display:grid;gap:1.4rem}
.grid-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.grid-cats{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:.18s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card-media{aspect-ratio:5/4;background:linear-gradient(135deg,var(--peach-soft),#fbe9f2);position:relative;display:flex;align-items:center;justify-content:center;color:var(--peach-deep);font-family:var(--serif);font-size:2.4rem;font-weight:600;overflow:hidden}
.card-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.card-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.card-body h3{margin:0;font-size:1.1rem}
.card-body h3 a{color:var(--plum)}
.card-loc{font-size:.86rem;color:var(--muted);display:flex;align-items:center;gap:.3rem}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.5rem}
.view{font-size:.86rem;color:var(--peach-deep);font-weight:600}

/* ---------- Badges ---------- */
.badges{display:flex;flex-wrap:wrap;gap:.35rem}
.badge{font-size:.71rem;font-weight:600;padding:.22rem .6rem;border-radius:999px;background:var(--peach-soft);color:var(--peach-deep);white-space:nowrap}
.badge-soft{background:#f4eef1;color:var(--muted)}
.badge-rating{background:#fff4d6;color:#a9750a}

/* ---------- Category tiles ---------- */
.cat-tile{display:flex;flex-direction:column;justify-content:space-between;gap:.6rem;padding:1.3rem;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);min-height:118px;transition:.16s}
.cat-tile:hover{text-decoration:none;border-color:var(--peach);transform:translateY(-3px)}
.cat-tile b{font-family:var(--serif);color:var(--plum);font-size:1.12rem;font-weight:600}
.cat-tile .count{font-size:.82rem;color:var(--muted)}
.cat-tile .arrow{color:var(--peach-deep);font-weight:700}

/* chips (country / link lists) */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;list-style:none;padding:0;margin:0}
.chips a{display:inline-block;padding:.5rem .95rem;border-radius:999px;background:#fff;border:1px solid var(--line-2);color:var(--ink);font-size:.9rem}
.chips a:hover{border-color:var(--peach);color:var(--peach-deep);text-decoration:none}
.chips .count{color:var(--muted);font-size:.82em}

/* ---------- Section heading row ---------- */
.sec-head{display:flex;justify-content:space-between;align-items:end;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.sub{color:var(--muted);margin-top:-.3rem;margin-bottom:1.6rem}

/* ---------- Page header band ---------- */
.page-band{background:#fff;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-band--img{min-height:240px;display:flex;align-items:flex-end;background-size:cover;background-position:center}
.page-band--img .wrap{position:relative;z-index:1;color:#fff;padding-bottom:1.8rem}
.page-band--img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(42,23,38,.15),rgba(42,23,38,.78))}
.page-band--img h1,.page-band--img .crumbs,.page-band--img .crumbs a,.page-band--img .muted{color:#fff}

/* ---------- Profile page ---------- */
.profile-hero{aspect-ratio:21/7;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,var(--peach-soft),#fbe9f2);margin-bottom:1.5rem}
.profile-hero img{width:100%;height:100%;object-fit:cover}
.profile-head{display:grid;grid-template-columns:120px 1fr;gap:1.5rem;align-items:start}
.profile-avatar{width:120px;height:120px;border-radius:24px;background:linear-gradient(135deg,var(--peach),var(--peach-deep));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:2.6rem;font-weight:600;box-shadow:var(--shadow);overflow:hidden}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-grid{display:grid;grid-template-columns:1fr 320px;gap:2rem;margin-top:2rem;align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}
.panel h2{font-size:1.18rem}
.kv{list-style:none;padding:0;margin:0}
.kv li{display:flex;gap:.6rem;padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.94rem}
.kv li:last-child{border-bottom:0}
.kv .k{color:var(--muted);min-width:92px;flex:0 0 auto}
.sticky{position:sticky;top:88px}
@media(max-width:860px){.profile-grid{grid-template-columns:1fr}}
@media(max-width:520px){.profile-head{grid-template-columns:1fr;text-align:center;justify-items:center}}

/* social row */
.social{display:flex;flex-wrap:wrap;gap:.5rem}
.social a{width:38px;height:38px;border-radius:50%;background:var(--peach-soft);display:flex;align-items:center;justify-content:center;color:var(--peach-deep);font-weight:700;font-size:.78rem}
.social a:hover{background:var(--peach);color:#fff;text-decoration:none}

/* ---------- Filters ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:.85rem 1rem;margin-bottom:1.5rem}
.filters select,.filters input{padding:.5rem .7rem;border:1px solid var(--line-2);border-radius:var(--radius-sm);font-size:.9rem;background:#fff;color:var(--ink);font-family:inherit}
.filters label{font-size:.76rem;color:var(--muted);display:flex;flex-direction:column;gap:.25rem}

/* ---------- Forms ---------- */
.field{margin-bottom:1rem}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--plum);margin-bottom:.3rem}
.field input,.field textarea,.field select{width:100%;padding:.7rem .85rem;border:1px solid var(--line-2);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:#fff}
.field textarea{min-height:120px;resize:vertical}
.alert{padding:.85rem 1rem;border-radius:var(--radius-sm);font-size:.92rem;margin-bottom:1rem}
.alert-success{background:#e8f8ee;color:#1c7a44;border:1px solid #bfe9cf}
.alert-error{background:#fdeaea;color:#b3261e;border:1px solid #f5c6c6}

/* ---------- Breadcrumb ---------- */
.crumbs{font-size:.84rem;color:var(--muted);margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.4rem}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--peach-deep)}

/* ---------- Pagination ---------- */
.pagination{margin-top:2rem}
.pagination,.pagination ul{display:flex;gap:.35rem;list-style:none;padding:0;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;padding:0 .6rem;border-radius:var(--radius-sm);border:1px solid var(--line-2);background:#fff;color:var(--ink);font-size:.9rem}
.pagination a:hover{border-color:var(--peach);text-decoration:none}

/* ---------- Notice / disclaimer banner ---------- */
.notice{background:var(--plum);color:#ffd9df;font-size:.82rem;text-align:center;padding:.5rem 1rem}
.notice a{color:#fff;text-decoration:underline}

/* ---------- Prose ---------- */
.prose{max-width:46rem}
.prose p{color:var(--ink);opacity:.9}

/* ---------- Footer ---------- */
.site-footer{background:var(--plum);color:#e9dbe2;margin-top:4rem;padding:3rem 0 2rem}
.site-footer a{color:#f4d9e0}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2rem}
.footer-grid h4{font-family:var(--serif);color:#fff;font-size:1rem;margin-bottom:.8rem;letter-spacing:0;font-weight:600}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:.5rem;font-size:.9rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1.5rem;font-size:.82rem;color:#c9b3bd;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.footer-grid{grid-template-columns:1fr}}
