/*
Theme Name: Colocation Mulhouse (Cosy)
Theme URI: https://example.com/
Author: Alexandre
Author URI: https://example.com/
Description: Variante "cosy" du thème pour présenter la colocation meublée du 1 rue du Cygne à Mulhouse. Tons chauds, mise en page claire, galerie, chambres, prestations et formulaire de contact. Compatible Yoast SEO.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: colocation-mulhouse-cosy
Tags: real-estate, custom-colors, custom-menu, full-width-template, translation-ready
*/

:root{
    --cream:#FBF6EE;--cream-2:#F4EADB;--cream-3:#EFE3CF;--terracotta:#C5663E;--terracotta-deep:#A4502E;
    --olive:#6B6B47;--ink:#2E2620;--ink-soft:#5A4F45;--gold:#D9A45B;--line:#E3D5C2;
    --white:#FFFDFA;
    --shadow:rgba(70,48,30,0.10);
    --shadow-sm:0 2px 10px rgba(70,48,30,0.06);
    --shadow-md:0 10px 30px rgba(70,48,30,0.10);
    --shadow-lg:0 22px 50px rgba(70,48,30,0.16);
    --ease:cubic-bezier(.22,.61,.36,1);
    --ease-out:cubic-bezier(.16,1,.3,1);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--cream);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
  h1,h2,h3{font-family:Georgia,"Times New Roman",serif;font-weight:600;line-height:1.12;letter-spacing:-.01em}
  ::selection{background:var(--terracotta);color:var(--white)}
  img{display:block;max-width:100%}
  .container{max-width:1280px;margin:0 auto;padding:0 clamp(16px,3.5vw,28px)}

  /* NAV */
  nav{position:sticky;top:0;z-index:100;background:rgba(251,246,238,0.82);backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--line);transition:box-shadow .3s var(--ease),background .3s var(--ease)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
  .logo{font-family:Georgia,'Times New Roman',serif;font-size:1.28rem;font-weight:600;letter-spacing:.2px;display:inline-flex;align-items:center;gap:10px;color:var(--ink);text-decoration:none;list-style:none;transition:color .25s var(--ease)}
  .logo:hover{color:var(--terracotta-deep)}
  .logo .dot{width:9px;height:9px;border-radius:50%;background:var(--terracotta);flex-shrink:0;box-shadow:0 0 0 4px rgba(197,102,62,.14);transition:box-shadow .3s var(--ease)}
  .logo:hover .dot{box-shadow:0 0 0 6px rgba(197,102,62,.2)}
  .logo img{max-height:40px;width:auto}
  .nav-links{display:flex;gap:32px;align-items:center;list-style:none;margin:0;padding:0}
  .nav-links li{list-style:none;margin:0}
  .nav-links a{position:relative;color:var(--ink-soft);text-decoration:none;font-size:.92rem;font-weight:500;transition:color .25s var(--ease)}
  .nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:1.5px;background:var(--terracotta);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease-out)}
  .nav-links a:not(.nav-cta):hover{color:var(--terracotta)}
  .nav-links a:not(.nav-cta):hover::after{transform:scaleX(1);transform-origin:left}
  .nav-cta{background:var(--terracotta);color:var(--white)!important;padding:10px 22px;border-radius:40px;box-shadow:0 6px 16px rgba(197,102,62,.24);transition:background .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease)}
  .nav-cta:hover{background:var(--terracotta-deep);transform:translateY(-2px);box-shadow:0 10px 22px rgba(197,102,62,.34)}
  @media(max-width:760px){
    .nav-links{display:none}
    .nav-inner{height:60px}
    .logo{font-size:1.12rem}
    .logo .dot{width:8px;height:8px}
  }

  /* BANDEAU MOBILE "Réserver une visite" (fixe en bas) */
  .mobile-cta{display:none}
  @media(max-width:760px){
    .mobile-cta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:200;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(251,246,238,0.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);box-shadow:0 -4px 20px rgba(70,48,30,0.1)}
    .mobile-cta a{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:40px;background:var(--terracotta);color:var(--white);text-decoration:none;font-weight:600;font-size:1rem;box-shadow:0 6px 16px rgba(197,102,62,.3)}
    .mobile-cta a:active{background:var(--terracotta-deep)}
    /* Évite que le bandeau cache le bas de page */
    body{padding-bottom:74px}
    footer{padding-bottom:calc(32px + 74px)}
  }

  /* HERO */
  .hero{position:relative;padding:clamp(48px,7vw,80px) 0 clamp(40px,6vw,60px);overflow:hidden}
  .hero::before{content:"";position:absolute;top:-120px;right:-100px;width:480px;height:480px;background:radial-gradient(circle,rgba(217,164,91,.28),transparent 68%);border-radius:50%;z-index:0}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;z-index:1}
  .badge{display:inline-flex;align-items:center;gap:8px;background:var(--cream-2);border:1px solid var(--line);color:var(--terracotta-deep);padding:7px 15px;border-radius:40px;font-size:.82rem;font-weight:600;letter-spacing:.4px;text-transform:uppercase;margin-bottom:24px}
  .badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--terracotta);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(197,102,62,.5)}70%{box-shadow:0 0 0 10px rgba(197,102,62,0)}100%{box-shadow:0 0 0 0 rgba(197,102,62,0)}}
  .hero h1{font-size:clamp(2rem,3.4vw,3rem);letter-spacing:-.5px;margin-bottom:20px;max-width:14ch}
  .hero h1 em{font-style:italic;color:var(--terracotta);font-weight:500}
  .hero p.lead{font-size:1.12rem;color:var(--ink-soft);max-width:520px;margin-bottom:14px}
  .hero .loc{display:flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:.98rem;margin-bottom:30px;font-weight:500}
  .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
  .btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;border-radius:44px;font-weight:600;font-size:.98rem;text-decoration:none;cursor:pointer;border:none;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),background .3s var(--ease)}
  .btn-primary{background:var(--terracotta);color:var(--white);box-shadow:0 10px 26px rgba(197,102,62,.32)}
  .btn-primary:hover{background:var(--terracotta-deep);transform:translateY(-3px);box-shadow:0 16px 34px rgba(197,102,62,.42)}
  .btn-primary:active{transform:translateY(-1px)}
  .btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
  .btn-ghost:hover{border-color:var(--terracotta);color:var(--terracotta);background:rgba(197,102,62,.05)}

  .hero-media{position:relative;height:480px}
  .hm{position:absolute;border-radius:16px;overflow:hidden;box-shadow:0 20px 45px rgba(70,48,30,0.22);transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out)}
  .hm img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
  .hm:hover{box-shadow:0 28px 60px rgba(70,48,30,0.3);z-index:5}
  .hm:hover img{transform:scale(1.06)}
  .hm-1{top:0;left:0;width:64%;height:62%;z-index:2}
  .hm-2{bottom:0;left:8%;width:46%;height:42%;z-index:3}
  .hm-3{top:14%;right:0;width:42%;height:56%;z-index:1;transform:rotate(2deg)}
  .hm-3:hover{transform:rotate(0)}
  @media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:clamp(28px,5vw,36px)}.hero-media{height:clamp(320px,52vw,420px);order:-1}}
  @media(max-width:480px){.hero-actions .btn{flex:1 1 auto;justify-content:center}}

  /* STATS */
  .stats{background:var(--ink);color:var(--cream)}
  .stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:clamp(28px,4vw,40px) 0}
  .stat{text-align:center;padding:8px 14px;position:relative}
  .stat:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:46px;background:rgba(217,164,91,.22)}
  .stat .num{font-family:Georgia,'Times New Roman',serif;font-size:2.1rem;color:var(--gold);font-weight:600;line-height:1}
  .stat .lbl{font-size:.85rem;color:#cbbda9;letter-spacing:.4px;margin-top:6px}
  @media(max-width:620px){.stats-inner{grid-template-columns:repeat(2,1fr);gap:26px 0}.stat:nth-child(2)::after{display:none}}

  section{padding:clamp(56px,8vw,88px) 0}
  .sec-head{max-width:620px;margin-bottom:clamp(34px,5vw,52px)}
  .sec-kicker{display:inline-flex;align-items:center;gap:9px;color:var(--terracotta);font-weight:600;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
  .sec-kicker::before{content:"";width:26px;height:1.5px;background:var(--terracotta);display:inline-block}
  .sec-head h2{font-size:clamp(1.7rem,2.8vw,2.35rem);margin-bottom:16px}
  .sec-head p{color:var(--ink-soft);font-size:1.06rem;line-height:1.7}

  /* FEATURES */
  .features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .feat{position:relative;background:var(--white);border:1px solid var(--line);border-radius:20px;padding:32px 28px;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s var(--ease-out)}
  .feat:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
  .feat .ic{width:54px;height:54px;border-radius:15px;background:linear-gradient(145deg,var(--cream-2),var(--cream-3));display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--terracotta);transition:transform .35s var(--ease-out),background .35s var(--ease-out)}
  .feat:hover .ic{transform:scale(1.08) rotate(-3deg);background:linear-gradient(145deg,var(--terracotta),var(--terracotta-deep));color:var(--white)}
  .feat h3{font-size:1.2rem;margin-bottom:9px;font-weight:600}
  .feat p{color:var(--ink-soft);font-size:.95rem;line-height:1.65}
  @media(max-width:880px){.features{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.features{grid-template-columns:1fr}}

  /* GALLERY */
  .gallery-sec{background:var(--cream-2)}
  .gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:185px;gap:16px}
  .gphoto{border-radius:14px;overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--shadow-md);transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out)}
  .gphoto .cap{position:absolute;left:13px;bottom:13px;z-index:2;background:rgba(46,38,32,.72);color:#fff;font-size:.74rem;font-weight:600;letter-spacing:.3px;padding:5px 12px;border-radius:30px;backdrop-filter:blur(6px);transform:translateY(4px);opacity:.85;transition:transform .4s var(--ease-out),opacity .4s var(--ease-out);pointer-events:none}
  .gphoto::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(46,38,32,.32),transparent 55%);opacity:0;transition:opacity .4s var(--ease-out);pointer-events:none}
  .gphoto:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .gphoto:hover::after{opacity:1}
  .gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
  .gphoto:hover img{transform:scale(1.07)}
  .gphoto:hover .cap{transform:translateY(0);opacity:1}
  .g-wide{grid-column:span 2}
  .g-tall{grid-row:span 2}
  @media(max-width:820px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.g-tall{grid-row:span 1}.g-wide{grid-column:span 2}}
  @media(max-width:480px){.gallery{grid-template-columns:1fr;grid-auto-rows:220px}.g-wide{grid-column:span 1}}

  /* ROOMS */
  .rooms{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
  .rooms.rooms-single{grid-template-columns:minmax(280px,420px);justify-content:center}
  .room{border-radius:18px;overflow:hidden;background:var(--white);display:flex;flex-direction:column;box-shadow:0 8px 24px rgba(70,48,30,0.12);transition:box-shadow .3s var(--ease-out),transform .3s var(--ease-out)}
  .room:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}
  .room-img{height:210px;position:relative;overflow:hidden;flex:0 0 auto}
  .room-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
  .room:hover .room-img img{transform:scale(1.06)}
  .room-status{position:absolute;top:14px;left:14px;padding:6px 13px;border-radius:30px;font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;box-shadow:0 4px 12px rgba(46,38,32,.18)}
  .st-available{background:var(--terracotta);color:var(--white)}
  .room-body{padding:24px 26px;flex:1 1 auto;display:flex;flex-direction:column;min-height:0}
  .room-body h3{font-size:1.32rem;margin-bottom:4px}
  .room-meta{color:var(--ink-soft);font-size:.92rem;margin-bottom:18px}
  .room-price{margin-top:auto;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
  .room-price .amt{font-family:Georgia,'Times New Roman',serif;font-size:1.95rem;color:var(--terracotta-deep);font-weight:600}
  .room-price .per{color:var(--ink-soft);font-size:.88rem}
  .room-price .inc{margin-left:auto;font-size:.74rem;background:var(--cream-2);padding:4px 11px;border-radius:20px;color:var(--olive);font-weight:600}
  .room-cta{margin-top:18px}
  .room-cta a{display:block;text-align:center;padding:13px;border-radius:40px;background:var(--ink);color:var(--cream);text-decoration:none;font-weight:600;font-size:.92rem;transition:background .25s var(--ease)}
  .room-cta a:hover{background:var(--terracotta)}

  /* INCLUDED */
  .included-sec{background:var(--ink);color:var(--cream)}
  .included-sec .sec-head h2{color:var(--cream)}
  .included-sec .sec-kicker{color:var(--gold)}
  .included-sec .sec-head p{color:#cbbda9}
  .incl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .incl{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:18px 20px;transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease-out)}
  .incl:hover{background:rgba(255,255,255,.08);border-color:rgba(217,164,91,.3);transform:translateY(-3px)}
  .incl .ck{width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;transition:transform .3s var(--ease-out)}
  .incl:hover .ck{transform:scale(1.12)}
  .incl span.t{font-size:.98rem;font-weight:500}
  @media(max-width:820px){.incl-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.incl-grid{grid-template-columns:1fr}}

  /* LOCATION */
  .loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
  .loc-map{height:360px;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-md)}
  .loc-map iframe{width:100%;height:100%;border:0}
  .transit{list-style:none;margin-top:20px}
  .transit li{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px dashed var(--line);font-size:.98rem;color:var(--ink-soft);transition:transform .3s var(--ease-out)}
  .transit li:hover{transform:translateX(4px)}
  .transit li b{color:var(--ink)}
  .transit .tIc{width:38px;height:38px;border-radius:11px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;color:var(--terracotta);flex-shrink:0;transition:background .3s var(--ease),color .3s var(--ease)}
  .transit li:hover .tIc{background:var(--terracotta);color:var(--white)}
  @media(max-width:820px){.loc-grid{grid-template-columns:1fr;gap:30px}}

  /* CONTACT */
  .contact-sec{background:var(--cream-2)}
  .contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
  .contact-info h2{font-size:clamp(1.7rem,2.8vw,2.2rem);margin-bottom:16px}
  .contact-info p{color:var(--ink-soft);margin-bottom:24px;font-size:1.04rem;line-height:1.7}
  .contact-info .ci-item{display:flex;gap:13px;align-items:center;margin-bottom:14px;font-weight:500}
  .contact-info .ci-item .ic{width:42px;height:42px;border-radius:12px;background:var(--white);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--terracotta);flex-shrink:0}
  .form-card{background:var(--white);border:1px solid var(--line);border-radius:24px;padding:clamp(24px,4vw,38px);box-shadow:var(--shadow-lg)}
  .form-card h3{font-size:1.42rem;margin-bottom:6px}
  .form-card .fsub{color:var(--ink-soft);font-size:.94rem;margin-bottom:24px}
  .field{margin-bottom:18px}
  .field label{display:block;font-size:.86rem;font-weight:600;margin-bottom:7px;color:var(--ink)}
  .req{color:var(--terracotta)}
  .field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.96rem;background:var(--cream);color:var(--ink);transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
  .field input[type=date]{cursor:pointer}
  .field input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;color:var(--terracotta)}
  .field input:hover,.field select:hover,.field textarea:hover{border-color:var(--gold)}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--terracotta);background:var(--white);box-shadow:0 0 0 3px rgba(197,102,62,.13)}
  .field textarea{resize:vertical;min-height:96px}
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .form-card .btn-primary{width:100%;justify-content:center;margin-top:6px}
  .form-note{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:14px;line-height:1.5}
  .form-msg{display:none;padding:14px;border-radius:12px;font-size:.92rem;font-weight:500;margin-bottom:18px}
  .form-msg.ok{display:block;background:#e6efd9;color:#4d6b2f;border:1px solid #c9dcb0}
  .form-msg.err{display:block;background:#f5dcd2;color:#a4502e;border:1px solid #e7bda9}
  @media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px}.field-row{grid-template-columns:1fr}}

  /* LIGHTBOX */
  .lightbox{position:fixed;inset:0;background:rgba(30,22,16,.94);z-index:1000;display:none;align-items:center;justify-content:center;padding:30px;cursor:zoom-out;backdrop-filter:blur(4px);opacity:0;transition:opacity .3s var(--ease)}
  .lightbox.open{display:flex;opacity:1}
  .lightbox img{max-width:92%;max-height:88%;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
  .lightbox .lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1;font-family:serif;transition:transform .25s var(--ease),opacity .25s var(--ease);opacity:.8;z-index:2}
  .lightbox .lb-close:hover{transform:rotate(90deg);opacity:1}
  .lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:none;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s var(--ease),transform .25s var(--ease);backdrop-filter:blur(4px);z-index:2}
  .lightbox .lb-nav:hover{background:rgba(255,255,255,.22)}
  .lightbox .lb-prev{left:20px}
  .lightbox .lb-next{right:20px}
  .lightbox .lb-prev:hover{transform:translateY(-50%) scale(1.08)}
  .lightbox .lb-next:hover{transform:translateY(-50%) scale(1.08)}
  @media(max-width:600px){.lightbox .lb-nav{width:44px;height:44px;font-size:1.6rem}.lightbox .lb-prev{left:8px}.lightbox .lb-next{right:8px}}

  /* INTRO RÉDIGÉE */
  .intro-sec{background:var(--cream)}
  .intro-text{max-width:1080px}
  .intro-text h2{font-size:clamp(1.6rem,2.6vw,2.15rem);margin-bottom:24px;max-width:24ch}
  /* Deux colonnes façon magazine pour le corps du texte */
  @media(min-width:880px){
    .intro-body{column-count:2;column-gap:48px}
    .intro-body>h3{break-after:avoid}
  }
  .intro-body>*{break-inside:avoid}
  .intro-text h3{font-size:1.3rem;margin:0 0 12px;break-after:avoid}
  .intro-text h3:not(:first-child){margin-top:28px}
  .intro-text p{color:var(--ink-soft);font-size:1.04rem;line-height:1.75;margin-bottom:16px}
  .intro-text a{color:var(--terracotta-deep);text-decoration:underline;text-underline-offset:2px;transition:color .25s var(--ease)}
  .intro-text a:hover{color:var(--terracotta)}
  .intro-text strong{color:var(--ink);font-weight:600}
  .intro-text figure{margin:24px 0;break-inside:avoid}
  .intro-text figure img{width:100%;height:auto;border-radius:14px;box-shadow:var(--shadow-md)}
  .intro-text figcaption{margin-top:8px;font-size:.86rem;color:var(--ink-soft);font-style:italic;text-align:center}

  /* FAQ */
  .faq-sec{background:var(--cream-2)}
  .faq-list{max-width:820px}
  .faq-item{background:var(--white);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;transition:box-shadow .3s var(--ease-out)}
  .faq-item[open]{box-shadow:var(--shadow-md)}
  .faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:600;font-size:1.04rem;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:16px;transition:color .25s var(--ease)}
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary::after{content:"+";font-family:Georgia,serif;font-size:1.5rem;color:var(--terracotta);flex-shrink:0;transition:transform .3s var(--ease-out)}
  .faq-item[open] summary{color:var(--terracotta-deep)}
  .faq-item[open] summary::after{transform:rotate(45deg)}
  .faq-item summary:hover{color:var(--terracotta)}
  .faq-a{padding:0 24px 22px;color:var(--ink-soft);line-height:1.75}
  .faq-a p{margin:0;font-size:.98rem}

  /* FOOTER */
  footer{background:var(--ink);color:#cbbda9;padding:50px 0 32px}
  .foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
  .foot-inner .logo{color:var(--cream)}
  footer a{color:#cbbda9;text-decoration:none;transition:color .25s var(--ease)}
  footer a:hover{color:var(--gold)}
  .foot-bottom{margin-top:28px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);font-size:.84rem;text-align:center;color:#9a8e7d}

  .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
  .reveal.in{opacity:1;transform:none}
  @media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
