/* =============================================================
   PLAN YOUR MEMORIES — Core styles
   Aesthetic: soft blush-pink luxury (light, airy, romantic)
   ============================================================= */

:root{
    --blush:      #fdf3f5;   /* page background */
    --blush-2:    #fbe7ec;   /* alt section */
    --pink-soft:  #f7d9e1;
    --rose:       #d27a90;   /* primary accent */
    --rose-deep:  #b75f78;
    --plum:       #4a3038;   /* main text */
    --plum-2:     #6e5560;   /* muted text */
    --cream:      #fffafb;
    --gold:       #cca98a;
    --line:       rgba(74,48,56,.14);

    --serif: 'Cormorant Garamond', Georgia, serif;
    --sans:  'Jost', system-ui, sans-serif;
    --ease: cubic-bezier(.22,1,.36,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-font-smoothing:antialiased; scroll-behavior:auto;overflow-x:hidden; }
body{
    font-family:var(--sans); font-weight:300;
    background:var(--blush); color:var(--plum); line-height:1.7;
    overflow-x:hidden; cursor:none;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }

body::before{
    content:""; position:fixed; inset:0; z-index:9998; pointer-events:none;
    opacity:.03; mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- helpers ---------- */
.sec-eyebrow{ font-size:.72rem; letter-spacing:.42em; text-transform:uppercase;
    color:var(--rose); font-weight:400; margin-bottom:1rem; }
.sec-title{ font-family:var(--serif); font-weight:400;
    font-size:clamp(2.4rem,5.5vw,4.4rem); line-height:1.04; letter-spacing:-.01em; margin-bottom:1.4rem; }
.sec-title em{ font-style:italic; color:var(--rose); }
section{ position:relative; }

/* ===================== BUTTONS / LINKS ===================== */
.pym-btn{ display:inline-flex; align-items:center; gap:.6rem;
    font-family:var(--sans); font-size:.8rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase;
    color:#fff; background:var(--rose); padding:1.05rem 2.4rem; border-radius:60px; border:1px solid var(--rose);
    position:relative; overflow:hidden; transition:color .45s var(--ease); z-index:1; }
.pym-btn::after{ content:""; position:absolute; inset:0; z-index:-1; background:var(--rose-deep);
    transform:translateY(101%); transition:transform .5s var(--ease); }
.pym-btn:hover::after{ transform:translateY(0); }
.pym-btn--sm{ padding:.7rem 1.5rem; font-size:.7rem; }
.pym-btn--ghost{ background:transparent; color:var(--plum); border:1px solid var(--rose); }
.pym-btn--ghost::after{ background:var(--rose); }
.pym-btn--ghost:hover{ color:#fff; }

.pym-link-arrow{ font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--plum-2);
    position:relative; padding-bottom:3px; transition:color .35s; }
.pym-link-arrow::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
    background:var(--rose); transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.pym-link-arrow:hover{ color:var(--rose); }
.pym-link-arrow:hover::after{ transform:scaleX(1); transform-origin:left; }

/* ===================== CURSOR ===================== */
.pym-cursor{ position:fixed; top:0; left:0; width:38px; height:38px; border:1px solid var(--rose);
    border-radius:50%; transform:translate(-50%,-50%); pointer-events:none; z-index:10000;
    transition:width .3s var(--ease), height .3s var(--ease), background .3s; }
.pym-cursor-dot{ position:fixed; top:0; left:0; width:5px; height:5px; border-radius:50%;
    background:var(--rose); transform:translate(-50%,-50%); pointer-events:none; z-index:10001; }
.pym-cursor.is-hover{ width:60px; height:60px; background:rgba(210,122,144,.14); }
@media (hover:none){ body{cursor:auto;} .pym-cursor,.pym-cursor-dot{display:none;} }

/* ===================== PROGRESS ===================== */
.pym-progress{ position:fixed; top:0; left:0; height:3px; width:0%; z-index:9999;
    background:linear-gradient(90deg,var(--rose),var(--gold)); }

/* ===================== PRELOADER ===================== */
.pym-loader{ position:fixed; inset:0; z-index:10002; background:var(--rose);
    display:flex; align-items:center; justify-content:center; gap:.5rem;
    transition:transform .8s var(--ease);
    animation:loaderAutoOut .6s var(--ease) 2.6s forwards; }
.pym-loader.is-done{ transform:translateY(-100%); pointer-events:none; }
@keyframes loaderAutoOut{ to{ transform:translateY(-100%); visibility:hidden; pointer-events:none; } }
.pym-loader__inner{ display:flex; gap:.6rem; overflow:hidden; }
.pym-loader__word{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,5vw,3rem);
    color:#fff; transform:translateY(110%); opacity:0; animation:loadword .7s var(--ease) forwards; }
.pym-loader__word:nth-child(2){ animation-delay:.1s; }
.pym-loader__word:nth-child(3){ animation-delay:.2s; }
@keyframes loadword{ to{ transform:translateY(0); opacity:1; } }

/* ===================== NAVBAR ===================== */
.pym-nav{ position:fixed; top:0; left:0; width:100%; z-index:900; padding:1.5rem 0;
    transition:padding .4s var(--ease), background .4s, box-shadow .4s; }
.pym-nav.scrolled{ padding:.7rem 0; background:rgba(253,243,245,.85);
    backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line); }
.pym-nav__wrap{ display:flex; align-items:center; justify-content:space-between;
    max-width:1320px; margin:0 auto; padding:0 clamp(1.2rem,4vw,3rem); }
.pym-nav__brand{ display:flex; align-items:center; gap:.7rem; }
.pym-nav__brand img{ width:38px; height:38px; object-fit:contain; }
.pym-nav__brand span{ font-family:var(--serif); font-size:1.05rem; letter-spacing:.18em; }
.pym-nav__links{ display:flex; gap:2rem; }
.pym-nav__links a{ font-size:.78rem; letter-spacing:.13em; text-transform:uppercase;
    position:relative; padding:4px 0; color:var(--plum-2); transition:color .35s; }
.pym-nav__links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
    background:var(--rose); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease); }
.pym-nav__links a:hover,.pym-nav__links a.active{ color:var(--plum); }
.pym-nav__links a:hover::after,.pym-nav__links a.active::after{ transform:scaleX(1); transform-origin:left; }

.pym-burger{ background:none; border:none; width:34px; height:24px; position:relative; }
.pym-burger span{ position:absolute; left:0; height:1.5px; width:100%; background:var(--plum); transition:.35s var(--ease); }
.pym-burger span:first-child{ top:6px; } .pym-burger span:last-child{ bottom:6px; }
.pym-burger.open span:first-child{ top:11px; transform:rotate(45deg); }
.pym-burger.open span:last-child{ bottom:11px; transform:rotate(-45deg); }
.pym-mobile{ position:fixed; inset:0; z-index:850; background:var(--rose);
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.4rem;
    clip-path:circle(0% at 100% 0); transition:clip-path .6s var(--ease); }
.pym-mobile.open{ clip-path:circle(150% at 100% 0); }
.pym-mobile nav{ display:flex; flex-direction:column; align-items:center; gap:1rem; }
.pym-mobile a{ font-family:var(--serif); font-size:2rem; color:#fff; font-style:italic; }

/* ===================== HERO (3D depth) ===================== */
.hero{ min-height:100vh; display:flex; align-items:center; justify-content:center; text-align:center;
    padding:9rem 0 5rem; overflow:hidden;
    background:radial-gradient(ellipse at 50% 0%, var(--cream), var(--blush) 55%, var(--blush-2)); }
.hero__glow{ position:absolute; width:55vw; height:55vw; border-radius:50%;
    background:radial-gradient(circle,rgba(210,122,144,.16),transparent 60%);
    top:42%; left:50%; transform:translate(-50%,-50%); z-index:0; animation:floatglow 12s ease-in-out infinite; }
@keyframes floatglow{ 50%{ transform:translate(-52%,-46%) scale(1.12);} }
.hero__petals{ position:absolute; inset:0; z-index:1; pointer-events:none; }
.hero__petal{ position:absolute; width:14px; height:14px; background:var(--pink-soft);
    border-radius:0 80% 0 80%; opacity:.6; animation:petal linear infinite; }
@keyframes petal{ 0%{ transform:translateY(-10vh) rotate(0); opacity:0; }
    10%{opacity:.7;} 100%{ transform:translateY(110vh) rotate(360deg); opacity:0; } }

.hero__inner{ position:relative; z-index:2; }
.hero__eyebrow{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--rose); margin-bottom:.3rem; }
.hero__title{ font-family:var(--serif); font-weight:300; font-size:clamp(3.4rem,13vw,11rem);
    line-height:.92; letter-spacing:-.02em; }
.hero__line{ display:block; overflow:hidden; }
.hero__line span{ display:block; }
.hero__line--accent{ font-style:italic; color:var(--rose); }
.hero__media{ width:clamp(170px,22vw,240px); margin:1.6rem auto; position:relative;
    border-radius:200px 200px 12px 12px; overflow:hidden;
    box-shadow:0 30px 70px -30px rgba(183,95,120,.5); }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__media-ring{ position:absolute; inset:8px; border:1px solid rgba(255,255,255,.6);
    border-radius:190px 190px 8px 8px; pointer-events:none; }
.hero__sub{ max-width:480px; margin:0 auto 2rem; font-size:1.05rem; color:var(--plum-2); }
.hero__cta{ display:flex; gap:1.6rem; align-items:center; justify-content:center; flex-wrap:wrap; }
.hero__scroll{ position:absolute; bottom:4.8rem; left:50%; transform:translateX(-50%); z-index:2;
    display:flex; flex-direction:column; align-items:center; gap:.6rem;
    font-size:.66rem; letter-spacing:.3em; text-transform:uppercase; color:var(--plum-2); }
.hero__scroll-line{ width:1px; height:46px; background:var(--line); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; top:-46px; left:0; width:100%; height:46px;
    background:var(--rose); animation:scrolldrop 1.8s var(--ease) infinite; }
@keyframes scrolldrop{ to{ top:46px; } }
.marquee{ position:absolute; bottom:0; left:0; width:100%; overflow:hidden; padding:1rem 0;
    border-top:1px solid var(--line); background:rgba(255,255,255,.3); z-index:2; }
.marquee__track{ display:flex; gap:1.4rem; white-space:nowrap; width:max-content;
    animation:marquee 26s linear infinite; align-items:center; }
.marquee__track span{ font-family:var(--serif); font-style:italic; font-size:1.25rem; }
.marquee__track i{ color:var(--rose); font-style:normal; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ===================== ABOUT ===================== */
.about{ padding:clamp(6rem,12vw,10rem) 0; }
.about__media{ position:relative; }
.about__media img{ width:100%; border-radius:8px 120px 8px 8px; aspect-ratio:5/4; object-fit:cover; }
.about__badge{ position:absolute; bottom:-26px; left:-10px; background:var(--rose); color:#fff;
    padding:1.3rem 1.6rem; border-radius:6px; max-width:230px; box-shadow:0 24px 50px -22px rgba(183,95,120,.6); }
.about__badge span{ font-size:.8rem; opacity:.85; display:block; }
.about__badge strong{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:1.4rem; }
.about__text{ color:var(--plum-2); margin-bottom:1.4rem; font-size:1.02rem; }

/* ===================== EXPERTISE ===================== */
.expertise{ padding:clamp(4rem,9vw,8rem) 0; background:var(--blush-2); }
.expertise__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.xcard{ padding:2.6rem 2rem; background:var(--cream); border:1px solid var(--line); border-radius:14px;
    position:relative; transition:transform .45s var(--ease), box-shadow .45s; }
.xcard:hover{ transform:translateY(-8px); box-shadow:0 30px 60px -34px rgba(183,95,120,.4); }
.xcard__no{ font-family:var(--serif); font-style:italic; font-size:2.4rem; color:var(--pink-soft);
    display:block; margin-bottom:.6rem; }
.xcard__title{ font-family:var(--serif); font-weight:500; font-size:1.7rem; margin-bottom:.7rem; }
.xcard__text{ color:var(--plum-2); font-size:.97rem; }
.xcard__line{ display:block; width:36px; height:2px; background:var(--rose); margin-top:1.4rem; transition:width .45s var(--ease); }
.xcard:hover .xcard__line{ width:70px; }

/* ===================== SERVICES (clean grid, no scroll trap) ===================== */
.services{ padding:clamp(5rem,10vw,8rem) 0; }
.services__head{ text-align:center; margin-bottom:3.4rem; }
.services__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.svc{ padding:2.4rem 2rem; background:var(--cream); border:1px solid var(--line); border-radius:14px;
    position:relative; overflow:hidden; transition:transform .4s var(--ease); }
.svc::before{ content:""; position:absolute; top:0; left:0; width:100%; height:3px;
    background:var(--rose); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.svc:hover{ transform:translateY(-6px); }
.svc:hover::before{ transform:scaleX(1); }
.svc__index{ font-family:var(--serif); font-style:italic; font-size:1.6rem; color:var(--rose); }
.svc__title{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin:.4rem 0 .7rem; }
.svc__text{ color:var(--plum-2); font-size:.95rem; }

/* ===================== 3D COVERFLOW SCROLLER ===================== */
.show3d{ background:linear-gradient(180deg,var(--blush-2),var(--blush)); }
.show3d__head{ text-align:center; padding:clamp(2rem,2vw,1rem) 1rem 0; }
.show3d__stage{ height:100vh; display:flex; align-items:center; justify-content:center;
    perspective:1600px; overflow:hidden; }
.show3d__scene{ position:relative; width:min(440px,68vw); height:min(560px,72vh);
    transform-style:preserve-3d; }
.card3d{ position:absolute; inset:0; border-radius:14px; overflow:hidden; margin:0;
    box-shadow:0 40px 80px -30px rgba(74,48,56,.45); will-change:transform,opacity;
    backface-visibility:hidden; }
.card3d img{ width:100%; height:100%; object-fit:cover; }
.card3d__cap{ position:absolute; left:0; bottom:0; width:100%; padding:1.4rem 1.6rem;
    background:linear-gradient(transparent,rgba(74,48,56,.7)); color:#fff;
    font-family:var(--serif); font-style:italic; font-size:1.3rem; }
.show3d__hint{ text-align:center; padding-bottom:clamp(3rem,6vw,5rem); }

/* ===================== TESTIMONIALS ===================== */
.quotes{ padding:clamp(2rem,2vw,1rem) 0; }
.quotes__stage{ position:relative; max-width:760px; margin:0 auto; min-height:260px; text-align:center; }
.quote{ position:absolute; inset:0; opacity:0; transform:translateY(20px);
    transition:opacity .6s var(--ease), transform .6s var(--ease); pointer-events:none; }
.quote.is-active{ opacity:1; transform:translateY(0); pointer-events:auto; position:relative; }
.quote__mark{ font-family:var(--serif); font-size:5rem; color:var(--pink-soft); line-height:.4; display:block; }
.quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,3vw,2.1rem);
    line-height:1.4; margin:1.4rem 0; color:var(--plum); }
.quote footer{ font-size:.8rem; letter-spacing:.24em; text-transform:uppercase; color:var(--rose); }
.quotes__dots{ display:flex; gap:.7rem; justify-content:center; margin-top:2.4rem; }
.quotes__dots button{ width:9px; height:9px; border-radius:50%; border:none; background:var(--line); transition:.35s; }
.quotes__dots button.is-active{ background:var(--rose); transform:scale(1.3); }

/* ===================== CTA ===================== */
.cta{ padding:clamp(6rem,12vw,11rem) 0; background:var(--rose); color:#fff; position:relative; overflow:hidden; }
.cta__glow{ position:absolute; width:50vw; height:50vw; border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.3),transparent 60%); top:-10%; left:50%; transform:translateX(-50%); }
.cta__title{ font-family:var(--serif); font-weight:300; font-size:clamp(3rem,9vw,7rem); line-height:1; position:relative; }
.cta__title em{ font-style:italic; }
.cta__sub{ max-width:420px; margin:1.4rem auto 2.4rem; color:rgba(255,255,255,.85); position:relative; }
.cta__actions{ display:flex; gap:1.6rem; align-items:center; justify-content:center; flex-wrap:wrap; position:relative; }
.cta .pym-btn{ background:#fff; border-color:#fff; color:var(--rose); }
.cta .pym-btn::after{ background:var(--plum); }
.cta .pym-btn:hover{ color:#fff; }
.cta__actions .pym-link-arrow{ color:#fff; }
.cta__actions .pym-link-arrow::after{ background:#fff; }

/* ===================== FOOTER ===================== */
.pym-footer{ background:var(--blush-2); padding:clamp(4rem,8vw,6rem) 0 2rem; }
.pym-footer__brand{ display:flex; align-items:center; gap:.7rem; margin-bottom:1.2rem; }
.pym-footer__brand img{ width:42px; }
.pym-footer__brand span{ font-family:var(--serif); font-size:1.2rem; letter-spacing:.14em; }
.pym-footer__tag{ color:var(--plum-2); max-width:340px; }
.pym-footer h6{ font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--rose); margin-bottom:1.2rem; }
.pym-footer ul{ list-style:none; }
.pym-footer ul li{ margin-bottom:.7rem; }
.pym-footer ul a{ color:var(--plum-2); transition:color .3s, padding .3s; overflow-wrap:anywhere; word-break:break-word; }
.pym-footer ul a:hover{ color:var(--rose); padding-left:5px; }
.pym-footer__email{ font-size:.92rem; }
@media (max-width:575px){
    .pym-footer__col{ flex:0 0 100%; max-width:100%; }
}
.pym-footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem;
    margin-top:3.4rem; padding-top:1.6rem; border-top:1px solid var(--line); font-size:.78rem; color:var(--plum-2); }

/* ===================== REVEAL ===================== */
/* Content is ALWAYS visible. Entrance animations are added by JS as decoration only. */
.reveal,.reveal-up,.reveal-scale,.reveal-img{ opacity:1; }

/* ===================== RESPONSIVE ===================== */
@media (max-width:991px){
    .expertise__grid,.services__grid{ grid-template-columns:1fr; }
    .about__badge{ position:relative; bottom:0; left:0; margin-top:1rem; max-width:none; }
    .about__media img{ border-radius:8px 80px 8px 8px; }
}
@media (max-width:767px){
    body{ cursor:auto; }
    .hero__cta{ flex-direction:column; }
    .show3d__stage{ height:auto; min-height:62vh; padding:2rem 0; perspective:1000px; }
    .show3d__scene{ width:74vw; height:58vh; }
}

/* ===================== STATS ===================== */
.stats{ padding:clamp(3rem,6vw,4.5rem) 0; background:var(--rose); color:#fff; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; text-align:center; }
.stat__value{ font-family:var(--serif); font-size:clamp(2.6rem,5vw,4rem); display:block; line-height:1; }
.stat__label{ font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; opacity:.9; }

/* ===================== APPROACH ===================== */
.approach{ padding:clamp(6rem,11vw,10rem) 0; }
.approach__media img{ width:100%; border-radius:120px 8px 8px 8px; aspect-ratio:4/3; object-fit:cover;
    box-shadow:0 40px 80px -40px rgba(183,95,120,.5); }
.approach__text{ color:var(--plum-2); font-size:1.02rem; margin-bottom:1.6rem; }
.approach__list{ list-style:none; }
.approach__list li{ padding:.8rem 0; border-bottom:1px solid var(--line); color:var(--plum-2); }
.approach__list li span{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--rose); }

/* ===================== CATEGORIES ===================== */
.cats{ padding:clamp(5rem,10vw,8rem) 0; background:var(--blush-2); }
.cats__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.cat{ background:var(--cream); border-radius:16px; overflow:hidden; border:1px solid var(--line);
    transition:transform .45s var(--ease), box-shadow .45s; display:block; }
.cat:hover{ transform:translateY(-8px); box-shadow:0 34px 64px -36px rgba(183,95,120,.45); }
.cat__img{ aspect-ratio:5/4; overflow:hidden; }
.cat__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.cat:hover .cat__img img{ transform:scale(1.07); }
.cat__body{ padding:1.6rem 1.6rem 1.9rem; }
.cat__body h3{ font-family:var(--serif); font-weight:500; font-size:1.6rem; margin-bottom:.5rem; }
.cat__body p{ color:var(--plum-2); font-size:.95rem; margin-bottom:1rem; }
.cat__more{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--rose); }

/* ===================== 3D CAROUSEL controls ===================== */
.show3d__lead{ color:var(--plum-2); max-width:460px; margin:0 auto; }
.show3d__stage{ position:relative; }
.show3d__scene{ cursor:grab; }
.show3d__scene.is-dragging{ cursor:grabbing; }
.card3d{ cursor:pointer; }
.show3d__arrow{ position:absolute; top:50%; transform:translateY(-50%); z-index:200;
    width:58px; height:58px; border-radius:50%; border:1px solid var(--rose);
    background:rgba(255,255,255,.7); backdrop-filter:blur(6px); color:var(--rose);
    font-size:1.8rem; line-height:1; display:flex; align-items:center; justify-content:center;
    transition:background .35s, color .35s, transform .35s; }
.show3d__arrow:hover{ background:var(--rose); color:#fff; }
.show3d__arrow--prev{ left:clamp(1rem,5vw,4rem); }
.show3d__arrow--next{ right:clamp(1rem,5vw,4rem); }
.show3d__dots{ display:flex; gap:.7rem; justify-content:center; margin:1.4rem 0 2.4rem; }
.show3d__dots button{ width:9px; height:9px; border-radius:50%; border:none; background:var(--line);
    transition:.35s; cursor:pointer; }
.show3d__dots button.is-active{ background:var(--rose); transform:scale(1.35); }

/* ===================== PHOTO GALLERY (grid, guaranteed size) ===================== */
.gallery{ padding:clamp(2rem,2vw,1rem) 0; }
.gallery__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1.1rem; }
.gitem{ position:relative; overflow:hidden; border-radius:10px; margin:0; background:var(--pink-soft); }
.gitem img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1s var(--ease); }
.gitem:hover img{ transform:scale(1.06); }
.gitem:nth-child(1){ grid-row:span 2; }
.gitem:nth-child(2){ grid-row:span 2; }
.gitem:nth-child(4){ grid-row:span 2; }
.gitem:nth-child(7){ grid-row:span 2; }
.gitem__overlay{ position:absolute; inset:0; background:linear-gradient(transparent 55%,rgba(74,48,56,.4));
    opacity:0; transition:opacity .5s; }
.gitem:hover .gitem__overlay{ opacity:1; }

/* ===================== PHILOSOPHY ===================== */
.philosophy{ padding:clamp(5rem,10vw,8rem) 0; background:var(--blush-2); text-align:center; }
.philosophy__quote{ font-family:var(--serif); font-weight:300; font-style:italic;
    font-size:clamp(1.8rem,4.5vw,3.4rem); line-height:1.3; max-width:980px; margin:0 auto 1.2rem; }
.philosophy__quote em{ color:var(--rose); }
.philosophy__by{ font-size:.8rem; letter-spacing:.24em; text-transform:uppercase; color:var(--rose); }

/* ===================== INSTAGRAM ===================== */
.insta{ padding:clamp(2rem, 2vw,1rem) 0; text-align:center; }
.insta__handle{ display:inline-block; font-family:var(--serif); font-style:italic;
    font-size:1.6rem; color:var(--rose); margin:.4rem 0 2.6rem; }
.insta__row{ display:grid; grid-template-columns:repeat(5,1fr); gap:.8rem; }
.insta__cell{ position:relative; aspect-ratio:1; border-radius:10px; overflow:hidden; }
.insta__cell img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.insta__cell span{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    background:rgba(210,122,144,.55); color:#fff; font-size:1.8rem; opacity:0; transition:opacity .4s; }
.insta__cell:hover img{ transform:scale(1.1); }
.insta__cell:hover span{ opacity:1; }

/* ===================== RESPONSIVE (new sections) ===================== */
@media (max-width:991px){
    .stats__grid{ grid-template-columns:repeat(2,1fr); gap:2rem; }
    .cats__grid{ grid-template-columns:repeat(2,1fr); }
    .gallery__grid{ grid-template-columns:repeat(2,1fr); }
    .approach__media img{ border-radius:80px 8px 8px 8px; }
    .insta__row{ grid-template-columns:repeat(3,1fr); }
    .insta__cell:nth-child(4),.insta__cell:nth-child(5){ display:none; }
}
@media (max-width:767px){
    .cats__grid{ grid-template-columns:1fr; }
    .gallery__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
    .show3d__arrow{ width:46px; height:46px; font-size:1.4rem; }
    .show3d__arrow--prev{ left:.6rem; } .show3d__arrow--next{ right:.6rem; }
}

/* ===================== IMAGE PLACEHOLDERS (no empty gaps) ===================== */
.about__media,.approach__media{ min-height:320px; }
.about__media img,.approach__media img{ background:var(--pink-soft); }
.cat__img,.insta__cell{ background:var(--pink-soft); }
.card3d{ background:var(--pink-soft); }
img{ color:transparent; } /* hide broken-alt text flash */

/* ===================== INNER PAGE HERO ===================== */
.page-hero{ padding:12rem 0 5rem; text-align:center; position:relative; overflow:hidden;
    background:radial-gradient(ellipse at 50% 0%, var(--cream), var(--blush) 60%, var(--blush-2)); }
.page-hero__glow{ position:absolute; width:55vw; height:55vw; border-radius:50%;
    background:radial-gradient(circle,rgba(210,122,144,.14),transparent 60%);
    top:30%; left:50%; transform:translate(-50%,-50%); z-index:0; }
.page-hero__inner{ position:relative; z-index:2; }
.page-hero h1{ font-family:var(--serif); font-weight:300; font-size:clamp(3rem,9vw,6.5rem);
    line-height:1; letter-spacing:-.02em; }
.page-hero h1 em{ font-style:italic; color:var(--rose); }
.page-hero__sub{ max-width:600px; margin:1.6rem auto 0; color:var(--plum-2); font-size:1.05rem; }

/* ===================== STATEMENT BAND ===================== */
.statement{ padding:clamp(2rem,2vw,1rem) 0; background:var(--rose); color:#fff; text-align:center;
    position:relative; overflow:hidden; }
.statement__glow{ position:absolute; width:50vw; height:50vw; border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.25),transparent 60%); top:-15%; left:50%; transform:translateX(-50%); }
.statement h2{ font-family:var(--serif); font-weight:300; font-size:clamp(2.4rem,6vw,4.6rem);
    line-height:1.04; margin-bottom:1.4rem; position:relative; }
.statement h2 em{ font-style:italic; }
.statement p{ max-width:700px; margin:0 auto; color:rgba(255,255,255,.88); position:relative; }

/* ===================== ABOUT INTRO (two col) ===================== */
.aintro{ padding:clamp(6rem,11vw,9rem) 0; }
.aintro__img img{ width:100%; border-radius:8px 130px 8px 8px; aspect-ratio:4/5; object-fit:cover;
    background:var(--pink-soft); box-shadow:0 40px 80px -42px rgba(183,95,120,.5); }
.aintro__text{ color:var(--plum-2); font-size:1.04rem; margin-bottom:1.2rem; }

@media (max-width:991px){
    .aintro__img img{ border-radius:8px 90px 8px 8px; }
}

/* ===================== PORTFOLIO ===================== */
.pf-lead{ max-width:560px; margin:0 auto; color:var(--plum-2); text-align:center; }

.pf-filter{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin:0 auto 3.2rem; }
.pf-filter button{ font-family:var(--sans); font-size:.76rem; font-weight:400; letter-spacing:.12em;
    text-transform:uppercase; padding:.7rem 1.4rem; border-radius:50px; border:1px solid var(--line);
    background:transparent; color:var(--plum-2); cursor:pointer; transition:.35s var(--ease); }
.pf-filter button:hover{ border-color:var(--rose); color:var(--rose); }
.pf-filter button.is-active{ background:var(--rose); border-color:var(--rose); color:#fff; }

.pf-grid{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:260px; gap:1.1rem; }
.pf-item{ position:relative; overflow:hidden; border-radius:12px; cursor:pointer; margin:0;
    background:var(--pink-soft); }
.pf-item img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1s var(--ease); }
.pf-item:hover img{ transform:scale(1.07); }
.pf-item.is-hidden{ display:none; }
.pf-item__info{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
    padding:1.4rem; background:linear-gradient(transparent 40%, rgba(74,48,56,.65)); opacity:0; transition:opacity .45s; }
.pf-item:hover .pf-item__info{ opacity:1; }
.pf-item__cat{ font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--pink-soft); margin-bottom:.2rem; }
.pf-item__title{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:#fff; }
.pf-item__zoom{ position:absolute; top:1rem; right:1rem; width:42px; height:42px; border-radius:50%;
    background:rgba(255,255,255,.85); color:var(--rose); display:flex; align-items:center; justify-content:center;
    opacity:0; transform:scale(.6); transition:.4s var(--ease); font-size:1.2rem; }
.pf-item:hover .pf-item__zoom{ opacity:1; transform:scale(1); }
.pf-item:nth-child(6n+1){ grid-row:span 2; }
.pf-item:nth-child(6n+4){ grid-row:span 2; }

/* Lightbox */
.pf-lb{ position:fixed; inset:0; z-index:10005; background:rgba(44,37,33,.93); backdrop-filter:blur(6px);
    display:none; align-items:center; justify-content:center; }
.pf-lb.open{ display:flex; }
.pf-lb__img{ max-width:86vw; max-height:80vh; border-radius:10px; box-shadow:0 30px 90px rgba(0,0,0,.55);
    user-select:none; -webkit-user-drag:none; }
.pf-lb__cap{ position:absolute; bottom:2.2rem; left:0; width:100%; text-align:center; color:#fff;
    font-family:var(--serif); font-style:italic; font-size:1.25rem; pointer-events:none; }
.pf-lb__count{ position:absolute; top:1.8rem; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.7);
    font-size:.78rem; letter-spacing:.22em; pointer-events:none; }
.pf-lb__btn{ position:absolute; border-radius:50%; border:1px solid rgba(255,255,255,.4);
    background:rgba(255,255,255,.08); color:#fff; cursor:pointer; transition:.3s; display:flex;
    align-items:center; justify-content:center; }
.pf-lb__btn:hover{ background:rgba(255,255,255,.22); }
.pf-lb__close{ top:1.4rem; right:1.6rem; width:50px; height:50px; font-size:1.5rem; }
.pf-lb__nav{ top:50%; transform:translateY(-50%); width:56px; height:56px; font-size:1.9rem; }
.pf-lb__prev{ left:2.5vw; } .pf-lb__next{ right:2.5vw; }

@media (max-width:991px){ .pf-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:767px){
    .pf-grid{ grid-template-columns:1fr; grid-auto-rows:300px; }
    .pf-item:nth-child(6n+1),.pf-item:nth-child(6n+4){ grid-row:span 1; }
    .pf-lb__nav{ width:44px; height:44px; font-size:1.5rem; } .pf-lb__prev{ left:.6rem; } .pf-lb__next{ right:.6rem; }
    .pf-lb__img{ max-width:92vw; }
}

/* ===================== PORTFOLIO — category showcase (content) ===================== */
.pf-intro{ padding:clamp(4rem,8vw,6rem) 0 0; text-align:center; }
.pf-intro p{ max-width:680px; margin:0 auto; color:var(--plum-2); font-size:1.05rem; }

.pf-show-wrap{ padding:clamp(3rem,7vw,5rem) 0; }
.pf-show{ padding:clamp(2.5rem,5vw,4rem) 0; }
.pf-show__media img{ width:100%; border-radius:8px 110px 8px 8px; aspect-ratio:4/3; object-fit:cover;
    background:var(--pink-soft); box-shadow:0 40px 80px -44px rgba(183,95,120,.5); }
.pf-show--rev .pf-show__media img{ border-radius:110px 8px 8px 8px; }
.pf-show__no{ font-family:var(--serif); font-style:italic; font-size:3rem; color:var(--pink-soft);
    display:block; line-height:1; margin-bottom:.3rem; }
.pf-show__text{ color:var(--plum-2); font-size:1.02rem; margin:.4rem 0 1.6rem; }

@media (max-width:991px){ .pf-show__media img{ border-radius:8px 80px 8px 8px; } }

/* ===================== SERVICES — expertise strip + packages ===================== */
.svc-exp__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.svc-exp__img{ border-radius:12px; overflow:hidden; aspect-ratio:4/5; background:var(--pink-soft); }
.svc-exp__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.svc-exp__img:hover img{ transform:scale(1.06); }

.packages{ padding:clamp(5rem,10vw,8rem) 0; background:var(--blush-2); text-align:center; }
.packages__quote{ font-family:var(--serif); font-style:italic; font-weight:300;
    font-size:clamp(1.8rem,4vw,3rem); line-height:1.3; max-width:900px; margin:0 auto 1.6rem; }
.packages__quote em{ color:var(--rose); }
.packages__text{ max-width:640px; margin:0 auto 2rem; color:var(--plum-2); font-size:1.04rem; }

@media (max-width:767px){ .svc-exp__grid{ grid-template-columns:1fr; } }

/* ===================== SERVICES — interactive accordion ===================== */
.svc-acc{ max-width:1040px; margin:0 auto; }
.svc-acc__item{ border-top:1px solid var(--line); }
.svc-acc__item:last-child{ border-bottom:1px solid var(--line); }
.svc-acc__head{ width:100%; background:none; border:none; cursor:pointer; text-align:left;
    display:flex; align-items:center; gap:1.4rem; padding:1.9rem .4rem; color:inherit; }
.svc-acc__no{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--rose);
    width:2.6rem; flex:none; }
.svc-acc__title{ font-family:var(--serif); font-weight:400; font-size:clamp(1.6rem,3.6vw,2.7rem);
    line-height:1.1; color:var(--plum); flex:1; transition:color .35s; }
.svc-acc__item:hover .svc-acc__title,
.svc-acc__item:not(.is-collapsed) .svc-acc__title{ color:var(--rose); }
.svc-acc__icon{ width:44px; height:44px; border-radius:50%; border:1px solid var(--line); flex:none;
    position:relative; transition:.4s var(--ease); }
.svc-acc__icon::before,.svc-acc__icon::after{ content:""; position:absolute; top:50%; left:50%;
    background:var(--rose); transition:.4s var(--ease); }
.svc-acc__icon::before{ width:14px; height:1.6px; transform:translate(-50%,-50%); }
.svc-acc__icon::after{ width:1.6px; height:14px; transform:translate(-50%,-50%); }
.svc-acc__item:not(.is-collapsed) .svc-acc__icon{ background:var(--rose); border-color:var(--rose); }
.svc-acc__item:not(.is-collapsed) .svc-acc__icon::before,
.svc-acc__item:not(.is-collapsed) .svc-acc__icon::after{ background:#fff; }
.svc-acc__item:not(.is-collapsed) .svc-acc__icon::after{ transform:translate(-50%,-50%) scaleY(0); }

.svc-acc__wrap{ display:grid; grid-template-rows:1fr; transition:grid-template-rows .55s var(--ease); }
.svc-acc__item.is-collapsed .svc-acc__wrap{ grid-template-rows:0fr; }
.svc-acc__wrapinner{ overflow:hidden; }
.svc-acc__body{ display:grid; grid-template-columns:1fr 1fr; gap:2.6rem; align-items:center;
    padding:.2rem .4rem 2.8rem; }
.svc-acc__text{ color:var(--plum-2); font-size:1.04rem; }
.svc-acc__img{ border-radius:8px 90px 8px 8px; overflow:hidden; aspect-ratio:4/3; background:var(--pink-soft); }
.svc-acc__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.svc-acc__item:hover .svc-acc__img img{ transform:scale(1.05); }

@media (max-width:767px){
    .svc-acc__body{ grid-template-columns:1fr; gap:1.4rem; }
    .svc-acc__img{ order:-1; border-radius:8px 60px 8px 8px; }
    .svc-acc__title{ font-size:1.5rem; }
}

/* ===================== FEATURED IN ===================== */
.press-marquee{ padding:2rem 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
    overflow:hidden; background:var(--cream); }
.press-marquee__track{ display:flex; gap:2.6rem; white-space:nowrap; width:max-content;
    animation:marquee 32s linear infinite; align-items:center; }
.press-marquee__track span{ font-family:var(--serif); font-style:italic;
    font-size:clamp(1.5rem,4vw,2.8rem); color:var(--plum); }
.press-marquee__track i{ color:var(--rose); font-style:normal; font-size:.9rem; }

.press-intro{ padding:clamp(4rem,8vw,6rem) 0 1rem; text-align:center; }
.press-intro p{ max-width:680px; margin:0 auto; color:var(--plum-2); font-size:1.05rem; }

.press-wall{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.press-card{ position:relative; padding:2.8rem 2rem; background:var(--cream); border:1px solid var(--line);
    border-radius:16px; text-align:center; display:block; overflow:hidden;
    transition:transform .45s var(--ease), box-shadow .45s; }
.press-card::before{ content:""; position:absolute; left:0; top:0; width:100%; height:3px;
    background:var(--rose); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.press-card:hover{ transform:translateY(-7px); box-shadow:0 32px 64px -38px rgba(183,95,120,.45); }
.press-card:hover::before{ transform:scaleX(1); }
.press-card__no{ font-family:var(--serif); font-style:italic; color:var(--pink-soft); font-size:1.1rem; display:block; }
.press-card__name{ font-family:var(--serif); font-weight:500; font-size:1.65rem; margin:.3rem 0 .4rem; color:var(--plum); }
.press-card__meta{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--plum-2); }
.press-card__link{ display:inline-block; margin-top:1.1rem; font-size:.72rem; letter-spacing:.14em;
    text-transform:uppercase; color:var(--rose); }

.recognition{ padding:clamp(5rem,10vw,8rem) 0; background:var(--rose); color:#fff; text-align:center;
    position:relative; overflow:hidden; }
.recognition__glow{ position:absolute; width:50vw; height:50vw; border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.22),transparent 60%); top:-15%; left:50%; transform:translateX(-50%); }
.recognition__num{ font-family:var(--serif); font-size:clamp(4.5rem,13vw,10rem); line-height:.9;
    display:block; position:relative; }
.recognition h2{ font-family:var(--serif); font-weight:300; font-size:clamp(1.8rem,4vw,3rem);
    margin-top:.4rem; position:relative; }
.recognition p{ max-width:560px; margin:1.2rem auto 0; color:rgba(255,255,255,.86); position:relative; }

.feat{ padding:clamp(5rem,10vw,8rem) 0; }
.feat-strip{ overflow:hidden; padding:1.2rem 0; }
.feat-strip__track{ display:flex; gap:1.2rem; width:max-content; animation:marquee 45s linear infinite; }
.feat-strip:hover .feat-strip__track{ animation-play-state:paused; }
.feat-card{ width:210px; flex:none; aspect-ratio:9/19; border-radius:16px; overflow:hidden;
    background:var(--pink-soft); box-shadow:0 24px 48px -26px rgba(74,48,56,.4); }
.feat-card img{ width:100%; height:100%; object-fit:cover; }

@media (max-width:991px){ .press-wall{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:767px){ .press-wall{ grid-template-columns:1fr; } .feat-card{ width:160px; } }

/* ===================== OUR TEAM ===================== */
.team-who{ padding:clamp(5rem,9vw,7rem) 0; text-align:center; }
.team-who p{ max-width:760px; margin:0 auto; color:var(--plum-2); font-size:1.05rem; }
.team-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.8rem; }
.team-card{ background:var(--cream); border:1px solid var(--line); border-radius:18px; overflow:hidden;
    display:grid; grid-template-columns:230px 1fr; transition:transform .45s var(--ease), box-shadow .45s; }
.team-card:hover{ transform:translateY(-6px); box-shadow:0 34px 64px -38px rgba(183,95,120,.4); }
.team-card__img{ background:var(--pink-soft); overflow:hidden; }
.team-card__img img{ width:100%; height:100%; object-fit:cover; min-height:300px; transition:transform 1s var(--ease); }
.team-card:hover .team-card__img img{ transform:scale(1.06); }
.team-card__body{ padding:1.9rem 1.7rem; }
.team-card__role{ font-size:.64rem; letter-spacing:.18em; text-transform:uppercase; color:var(--rose); }
.team-card__name{ font-family:var(--serif); font-weight:500; font-size:1.95rem; margin:.2rem 0 .8rem; }
.team-card__bio{ color:var(--plum-2); font-size:.92rem; }

@media (max-width:991px){ .team-grid{ grid-template-columns:1fr; } }
@media (max-width:575px){ .team-card{ grid-template-columns:1fr; } .team-card__img img{ min-height:340px; } }

/* ===================== CONTACT ===================== */
.contact{ padding:clamp(3rem,7vw,5rem) 0 clamp(5rem,10vw,8rem); }
.cinfo-list{ list-style:none; }
.cinfo{ display:flex; gap:1.1rem; align-items:center; padding:1.2rem 0; border-bottom:1px solid var(--line); }
.cinfo__icon{ width:48px; height:48px; border-radius:50%; background:var(--blush-2); color:var(--rose); flex:none;
    display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.cinfo__label{ font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--plum-2); display:block; }
.cinfo__val{ font-family:var(--serif); font-size:1.2rem; color:var(--plum); }
.cinfo__val:hover{ color:var(--rose); }
.contact__socials{ margin-top:1.6rem; }

.cform{ background:var(--cream); border:1px solid var(--line); border-radius:22px; padding:clamp(1.6rem,4vw,2.6rem); }
.cform__grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:flex; flex-direction:column; }
.field--full{ grid-column:1 / -1; }
.field label{ font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--plum-2); margin-bottom:.45rem; }
.field input,.field select,.field textarea{ font-family:var(--sans); font-weight:300; font-size:.95rem; color:var(--plum);
    background:var(--blush); border:1px solid var(--line); border-radius:10px; padding:.85rem 1rem; transition:border-color .3s, background .3s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--rose); background:#fff; }
.field textarea{ resize:vertical; min-height:120px; }
.cform .pym-btn{ margin-top:.4rem; cursor:pointer; }
.honeypot{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

.form-alert{ border-radius:12px; padding:1.1rem 1.3rem; margin-bottom:1.6rem; font-size:.95rem; }
.form-alert--ok{ background:#eaf6ec; border:1px solid #bcdcc2; color:#2f6b3b; }
.form-alert--err{ background:#fdeaee; border:1px solid #f2c2cd; color:#9b2c43; }
.form-alert ul{ margin:.4rem 0 0 1.1rem; }

.contact-map{ border-radius:18px; overflow:hidden; border:1px solid var(--line); height:clamp(260px,40vw,400px); margin-top:3rem; }
.contact-map iframe{ width:100%; height:100%; border:0; display:block; }

@media (max-width:767px){ .cform__grid{ grid-template-columns:1fr; } }

/* ===================== BLOG ===================== */
.blog-feat{ display:grid; grid-template-columns:1.15fr 1fr; gap:0; background:var(--cream);
    border:1px solid var(--line); border-radius:20px; overflow:hidden; margin-bottom:3.4rem; }
.blog-feat__img{ overflow:hidden; background:var(--pink-soft); min-height:340px; }
.blog-feat__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.blog-feat:hover .blog-feat__img img{ transform:scale(1.05); }
.blog-feat__body{ padding:clamp(1.8rem,4vw,3rem); display:flex; flex-direction:column; justify-content:center; }
.blog-tag{ display:inline-block; font-size:.64rem; letter-spacing:.18em; text-transform:uppercase;
    color:var(--rose); border:1px solid var(--rose); border-radius:50px; padding:.35rem .9rem; margin-bottom:1.2rem; align-self:flex-start; }
.blog-feat__title{ font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,3.5vw,2.8rem);
    line-height:1.15; margin-bottom:1rem; }
.blog-feat__excerpt{ color:var(--plum-2); margin-bottom:1.4rem; }
.blog-meta{ font-size:.78rem; letter-spacing:.06em; color:var(--plum-2); margin-bottom:1.4rem; }
.blog-meta b{ color:var(--plum); font-weight:400; }

.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.bcard{ background:var(--cream); border:1px solid var(--line); border-radius:16px; overflow:hidden;
    display:flex; flex-direction:column; transition:transform .45s var(--ease), box-shadow .45s; }
.bcard.is-hidden{ display:none; }
.bcard:hover{ transform:translateY(-7px); box-shadow:0 32px 64px -38px rgba(183,95,120,.42); }
.bcard__imgwrap{ aspect-ratio:3/2; overflow:hidden; background:var(--pink-soft); }
.bcard__imgwrap img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.bcard:hover .bcard__imgwrap img{ transform:scale(1.07); }
.bcard__body{ padding:1.6rem 1.5rem 1.8rem; display:flex; flex-direction:column; flex:1; }
.bcard__title{ font-family:var(--serif); font-weight:500; font-size:1.4rem; line-height:1.2; margin:.7rem 0 .6rem; }
.bcard__excerpt{ color:var(--plum-2); font-size:.92rem; flex:1; }
.bcard__meta{ font-size:.72rem; letter-spacing:.06em; color:var(--plum-2); margin-top:1.2rem;
    padding-top:1rem; border-top:1px solid var(--line); display:flex; justify-content:space-between; }

@media (max-width:991px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:767px){ .blog-feat{ grid-template-columns:1fr; } .blog-grid{ grid-template-columns:1fr; } }

/* ===================== SINGLE POST ===================== */
.post-hero{ padding:11rem 0 2rem; text-align:center; }
.post-back{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--rose); }
.post-hero__title{ font-family:var(--serif); font-weight:400; font-size:clamp(2.2rem,5vw,3.8rem);
    line-height:1.1; max-width:900px; margin:1.2rem auto .8rem; }
.post-hero__meta{ font-size:.82rem; letter-spacing:.06em; color:var(--plum-2); }
.post-hero__meta b{ color:var(--plum); font-weight:400; }
.post-cover{ max-width:1040px; margin:2.6rem auto 0; padding:0 clamp(1rem,4vw,2rem); }
.post-cover img{ width:100%; border-radius:16px; aspect-ratio:3/2; object-fit:cover; background:var(--pink-soft); }

.post-body{ max-width:760px; margin:0 auto; padding:clamp(2.5rem,6vw,4rem) clamp(1.2rem,4vw,1rem); }
.post-body p{ color:var(--plum-2); font-size:1.08rem; line-height:1.85; margin-bottom:1.4rem; }
.post-body h3{ font-family:var(--serif); font-weight:500; font-size:1.8rem; color:var(--plum); margin:2.2rem 0 .9rem; }
.post-body h4{ font-family:var(--sans); font-weight:500; font-size:1.05rem; color:var(--rose);
    letter-spacing:.02em; margin:1.4rem 0 .4rem; }
.post-body ul{ margin:0 0 1.4rem 1.2rem; color:var(--plum-2); }
.post-body li{ margin-bottom:.5rem; line-height:1.7; }
.post-body em{ color:var(--rose); font-style:italic; }

.post-share{ max-width:760px; margin:0 auto; padding:0 1.2rem 1rem; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.post-share span{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--plum-2); }
.post-share a{ width:42px; height:42px; border-radius:50%; border:1px solid var(--line); display:flex;
    align-items:center; justify-content:center; color:var(--rose); transition:.3s; }
.post-share a:hover{ background:var(--rose); color:#fff; border-color:var(--rose); }

.post-author{ max-width:760px; margin:2.5rem auto 0; padding:1.8rem clamp(1.2rem,4vw,2rem);
    background:var(--blush-2); border-radius:16px; display:flex; gap:1.2rem; align-items:center; }
.post-author__ava{ width:60px; height:60px; border-radius:50%; background:var(--rose); color:#fff;
    display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:1.6rem; flex:none; }
.post-author__name{ font-family:var(--serif); font-size:1.3rem; }
.post-author__role{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--plum-2); }

.related{ padding:clamp(4rem,8vw,6rem) 0; background:var(--cream); }

/* ===================== BLOG — refined journal layout ===================== */
.journal-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; }
.jcard{ display:flex; flex-direction:column; background:var(--cream); border:1px solid var(--line);
    border-radius:22px; overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s; }
.jcard:hover{ transform:translateY(-8px); box-shadow:0 42px 84px -44px rgba(183,95,120,.45); }
.jcard__imgwrap{ aspect-ratio:16/10; overflow:hidden; background:var(--pink-soft); position:relative; }
.jcard__imgwrap img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.jcard:hover .jcard__imgwrap img{ transform:scale(1.06); }
.jcard__cat{ position:absolute; top:1.2rem; left:1.2rem; background:rgba(253,243,245,.92);
    backdrop-filter:blur(4px); color:var(--rose); font-size:.64rem; letter-spacing:.18em; text-transform:uppercase;
    padding:.45rem 1rem; border-radius:50px; }
.jcard__body{ padding:1.9rem 1.9rem 2.1rem; display:flex; flex-direction:column; flex:1; }
.jcard__title{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,2.4vw,1.95rem);
    line-height:1.18; margin-bottom:.8rem; }
.jcard__excerpt{ color:var(--plum-2); font-size:.97rem; flex:1; }
.jcard__meta{ font-size:.74rem; letter-spacing:.06em; color:var(--plum-2); margin:1.4rem 0;
    padding-top:1.1rem; border-top:1px solid var(--line); display:flex; justify-content:space-between; }
.jcard__more{ font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; color:var(--rose);
    position:relative; align-self:flex-start; }
.jcard:hover .jcard__more{ letter-spacing:.2em; }

@media (max-width:767px){ .journal-grid{ grid-template-columns:1fr; } }
