
  :root{
    /* Luxury palette (Navy × Gold × Ivory) */
    --navy:#0B1E3F;
    --navy-soft:#13294D;
    --navy-light:#1E3563;
    --gold:#C9A24E;
    --gold-light:#D8B868;
    --gold-deep:#A88134;
    --ivory:#F6F2EA;
    --ivory-deep:#EDE5D4;
    --cream:#FAF6EE;
    --ink:#1A2238;
    --ink-soft:#4A4F5E;
    --gray-soft:#9A9CA3;
    --rose-accent:#C9847A;
    --line-green:#06C755;
    --white:#FFFFFF;
    --shadow:0 16px 50px rgba(11,30,63,.10);
    --shadow-deep:0 24px 70px rgba(11,30,63,.18);
    --shadow-gold:0 12px 40px rgba(201,162,78,.25);
    --max:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Noto Sans JP',-apple-system,BlinkMacSystemFont,sans-serif;
    color:var(--ink);background:var(--ivory);
    line-height:2;font-weight:400;letter-spacing:.05em;
    -webkit-font-smoothing:antialiased;
  }
  a{color:inherit;text-decoration:none;transition:.3s}
  img{max-width:100%;display:block}
  h1,h2,h3,h4{font-family:'Shippori Mincho B1',serif;font-weight:500;line-height:1.5;letter-spacing:.08em}
  .italiana{font-family:'Italiana',serif;letter-spacing:.15em}
  .cormorant{font-family:'Cormorant Garamond',serif}
  .container{max-width:var(--max);margin:0 auto;padding:0 32px}

  /* Ornament */
  .ornament-line{
    display:flex;align-items:center;justify-content:center;gap:18px;margin:24px auto 0;
  }
  .ornament-line::before,.ornament-line::after{
    content:"";width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  }
  .ornament-line span{
    font-family:'Italiana',serif;font-size:11px;letter-spacing:.5em;color:var(--gold);
  }

  /* ===== Header ===== */
  header{
    position:sticky;top:0;z-index:100;background:rgba(11,30,63,.94);
    backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,162,78,.25);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:84px}
  .logo{font-family:'Italiana',serif;font-size:26px;letter-spacing:.2em;color:var(--ivory)}
  .logo .dot{color:var(--gold)}
  .nav-links{display:flex;gap:36px;font-size:12px;font-weight:400;color:var(--ivory);letter-spacing:.18em}
  .nav-links a{opacity:.85}
  .nav-links a:hover{color:var(--gold);opacity:1}
  .nav-cta{
    background:var(--gold);color:var(--navy);padding:12px 26px;
    font-size:11px;font-weight:600;letter-spacing:.22em;display:inline-flex;align-items:center;gap:8px;
    border-radius:0;border:1px solid var(--gold);
  }
  .nav-cta:hover{background:transparent;color:var(--gold)}

  /* ===== Hamburger menu (mobile only) ===== */
  .menu-toggle{
    display:none;background:transparent;border:0;padding:0;cursor:pointer;
    width:36px;height:36px;flex-direction:column;justify-content:center;align-items:center;gap:6px;
    margin-left:14px;
  }
  .menu-toggle span{
    display:block;width:22px;height:1.5px;background:var(--ivory);transition:.25s;border-radius:1px;
  }
  .menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .mobile-menu{
    display:none;background:rgba(11,30,63,.98);backdrop-filter:blur(14px);
    border-top:1px solid rgba(201,162,78,.2);
    padding:8px 20px 20px;
  }
  .mobile-menu a{
    display:block;color:var(--ivory);font-size:14px;font-weight:400;letter-spacing:.18em;
    padding:14px 4px;border-bottom:1px solid rgba(201,162,78,.12);
  }
  .mobile-menu a:last-child{border-bottom:none}
  .mobile-menu a:hover{color:var(--gold)}
  .mobile-menu.is-open{display:block}

  /* ===== Hero ===== */
  .hero{
    padding:90px 0 110px;background:var(--navy);color:var(--ivory);
    position:relative;overflow:hidden;
  }
  .hero::before{
    content:"";position:absolute;top:60px;right:60px;width:160px;height:160px;
    border:1px solid var(--gold);border-radius:50%;opacity:.3;
  }
  .hero::after{
    content:"";position:absolute;bottom:80px;left:40px;width:90px;height:90px;
    border:1px solid var(--gold);border-radius:50%;opacity:.2;
  }
  .hero-campaign{
    display:inline-block;background:linear-gradient(135deg,#B8472E 0%,#D85838 100%);
    color:#fff;padding:11px 36px;border-radius:0;font-family:'Noto Sans JP',sans-serif;
    font-size:11px;letter-spacing:.35em;font-weight:600;margin-bottom:40px;
    box-shadow:0 8px 24px rgba(184,71,46,.4);position:relative;
  }
  .hero-inner{
    display:grid;grid-template-columns:1.15fr 1fr;gap:80px;align-items:center;
    position:relative;
  }
  .hero-eyebrow{
    font-family:'Italiana',serif;font-size:13px;letter-spacing:.5em;color:var(--gold);
    margin-bottom:28px;display:block;
  }
  .hero h1{
    font-size:44px;line-height:1.65;margin-bottom:32px;letter-spacing:.04em;
    font-weight:500;color:var(--ivory);
  }
  .hero h1 .accent{
    color:var(--gold-light);position:relative;display:inline-block;
  }
  .hero h1 .accent::after{
    content:"";position:absolute;bottom:-6px;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
  }
  .hero .sub{
    font-size:15.5px;color:rgba(246,242,234,.85);margin-bottom:48px;line-height:2.4;
    font-weight:300;letter-spacing:.08em;
  }
  .hero-trust{
    display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;
    padding:32px 0;border-top:1px solid rgba(201,162,78,.3);border-bottom:1px solid rgba(201,162,78,.3);
  }
  .trust-num{
    font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:400;color:var(--gold);
    line-height:1;margin-bottom:8px;letter-spacing:.04em;
  }
  .trust-num small{font-size:18px;margin-left:2px}
  .trust-label{
    font-size:10px;color:rgba(246,242,234,.7);letter-spacing:.25em;text-transform:uppercase;
  }
  .hero-ctas{display:flex;gap:16px;flex-wrap:wrap}
  .btn{
    display:inline-flex;align-items:center;gap:10px;padding:18px 36px;border-radius:0;
    font-weight:500;font-size:12px;transition:.3s;letter-spacing:.25em;cursor:pointer;border:none;
    font-family:'Noto Sans JP',sans-serif;
  }
  .btn-line{
    background:var(--line-green);color:#fff;box-shadow:0 10px 28px rgba(6,199,85,.3);
  }
  .btn-line:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(6,199,85,.45)}
  .btn-gold{
    background:var(--gold);color:var(--navy);border:1px solid var(--gold);
  }
  .btn-gold:hover{background:transparent;color:var(--gold)}
  .btn-ghost-light{
    background:transparent;color:var(--ivory);border:1px solid var(--ivory);
  }
  .btn-ghost-light:hover{background:var(--ivory);color:var(--navy)}

  /* Hero visual (person image) */
  .hero-visual{
    position:relative;aspect-ratio:4/5;background:var(--navy-soft);
    border:1px solid var(--gold);overflow:hidden;
    box-shadow:var(--shadow-gold);
  }
  .hero-visual img{width:100%;height:100%;object-fit:cover;object-position:center 18%;filter:saturate(.95)}
  .hero-visual::after{
    content:"";position:absolute;inset:14px;border:1px solid rgba(201,162,78,.4);pointer-events:none;
  }
  .hero-visual-tag{
    position:absolute;bottom:30px;left:30px;right:30px;background:rgba(11,30,63,.92);
    padding:16px 24px;border-left:2px solid var(--gold);z-index:2;
  }
  .hv-tag-eyebrow{
    font-family:'Italiana',serif;font-size:9px;letter-spacing:.4em;color:var(--gold);margin-bottom:4px;
  }
  .hv-tag-text{
    font-family:'Shippori Mincho B1',serif;font-size:14px;color:var(--ivory);letter-spacing:.1em;
  }

  /* ===== Section common ===== */
  section{padding:130px 0;position:relative}
  .section-head{text-align:center;margin-bottom:80px}
  .eyebrow{
    display:block;color:var(--gold-deep);font-size:12px;font-weight:500;
    letter-spacing:.5em;margin-bottom:14px;font-family:'Italiana',serif;
  }
  .section-head h2{
    font-size:36px;line-height:1.7;font-weight:500;letter-spacing:.12em;color:var(--ink);
  }
  .section-lead{
    max-width:680px;margin:32px auto 0;color:var(--ink-soft);font-size:14.5px;
    font-weight:300;line-height:2.2;
  }

  /* ===== Problems ===== */
  .problems{background:var(--cream);position:relative}
  .problems-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:60px}
  .problem-card{
    background:var(--white);padding:48px 32px;
    border:1px solid var(--ivory-deep);transition:.4s;position:relative;
  }
  .problem-card::before{
    content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:40px;height:1px;background:var(--gold);
  }
  .problem-card:hover{
    transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--shadow);
  }
  .problem-num{
    font-family:'Italiana',serif;color:var(--gold-deep);font-size:11px;
    letter-spacing:.45em;margin-bottom:20px;text-align:center;
  }
  .problem-card h3{
    font-size:18px;margin-bottom:18px;line-height:1.8;text-align:center;
    font-weight:500;letter-spacing:.08em;
  }
  .problem-card p{
    color:var(--ink-soft);font-size:13.5px;line-height:2.2;font-weight:300;letter-spacing:.05em;
  }

  /* ===== Reasons ===== */
  .reasons{background:var(--ivory)}
  .reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;margin-top:60px}
  .reason{text-align:center;padding:24px}
  .reason-num{
    font-family:'Cormorant Garamond',serif;font-size:72px;font-weight:300;color:var(--gold);
    line-height:1;margin-bottom:24px;letter-spacing:.05em;
  }
  .reason-divider{width:40px;height:1px;background:var(--gold);margin:0 auto 24px}
  .reason h3{
    font-size:24px;margin-bottom:20px;font-weight:500;letter-spacing:.15em;color:var(--navy);
  }
  .reason p{
    color:var(--ink-soft);font-size:14px;line-height:2.2;text-align:left;
    font-weight:300;letter-spacing:.05em;
  }

  /* ===== Services ===== */
  .services{background:var(--cream);position:relative}
  .services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px}
  .services-grid > .service-card:nth-child(5){grid-column:2/3}
  @media (max-width:1024px){
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .services-grid > .service-card:nth-child(5){grid-column:1/3;justify-self:center;max-width:calc(50% - 12px)}
  }
  @media (max-width:768px){
    .services-grid{grid-template-columns:1fr}
    .services-grid > .service-card:nth-child(5){grid-column:auto;max-width:none;justify-self:stretch}
  }
  .service-card{
    background:var(--white);padding:40px 30px;border:1px solid var(--ivory-deep);
    transition:.4s;text-align:center;
  }
  .service-card:hover{background:var(--cream);border-color:var(--gold);transform:translateY(-4px)}
  .service-icon{
    width:64px;height:64px;margin:0 auto 24px;border-radius:50%;
    background:var(--cream);border:1px solid var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-family:'Italiana',serif;color:var(--gold-deep);font-size:20px;letter-spacing:.05em;
  }
  .service-card h3{font-size:17px;margin-bottom:18px;font-weight:500;letter-spacing:.1em}
  .service-card h3 small{
    display:block;font-family:'Italiana',serif;font-size:10px;
    letter-spacing:.4em;color:var(--gold-deep);margin-top:6px;font-weight:400;
  }
  .service-list{list-style:none;font-size:13px;color:var(--ink-soft);line-height:2.2;font-weight:300}
  .service-list li::before{content:"・";color:var(--gold)}

  /* ===== Portfolio ===== */
  .portfolio{background:var(--navy);color:var(--ivory);position:relative}
  .portfolio::before,.portfolio::after{
    content:"";position:absolute;left:50%;transform:translateX(-50%);
    width:1px;height:22px;background:var(--gold);
  }
  .portfolio::before{top:14px}
  .portfolio::after{bottom:14px}
  .portfolio .section-head h2{color:var(--ivory)}
  .portfolio .section-lead{color:rgba(246,242,234,.75)}
  .portfolio-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:60px;
  }
  .pf-card{
    background:var(--navy-soft);padding:40px 32px;border:1px solid rgba(201,162,78,.2);
    transition:.4s;position:relative;
  }
  .pf-card::before{
    content:"";position:absolute;top:0;left:0;width:60px;height:1px;background:var(--gold);
  }
  .pf-card:hover{border-color:var(--gold);transform:translateY(-4px)}
  .pf-image{
    aspect-ratio:4/5;background:var(--ivory);margin-bottom:32px;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    border:1px solid rgba(201,162,78,.2);
  }
  .pf-image img{width:100%;height:100%;object-fit:contain;background:var(--ivory)}
  .pf-meta{
    font-family:'Italiana',serif;font-size:11px;letter-spacing:.4em;color:var(--gold);margin-bottom:12px;
  }
  .pf-card h3{
    font-size:20px;color:var(--ivory);margin-bottom:16px;font-weight:500;letter-spacing:.08em;line-height:1.7;
  }
  .pf-client{
    font-size:13px;color:var(--gold-light);margin-bottom:16px;letter-spacing:.1em;font-weight:300;
  }
  .pf-desc{
    color:rgba(246,242,234,.8);font-size:13.5px;line-height:2.1;font-weight:300;letter-spacing:.05em;
  }
  .pf-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
  .pf-tag{
    font-size:10px;border:1px solid rgba(201,162,78,.4);color:var(--gold);
    padding:4px 12px;letter-spacing:.15em;
  }
  /* SAMPLE badge for demo case */
  .pf-card.is-sample::after{
    content:"SAMPLE";position:absolute;top:20px;right:20px;
    background:var(--gold);color:var(--navy);
    font-family:'Italiana',serif;font-size:10px;letter-spacing:.35em;
    padding:5px 12px;font-weight:500;z-index:2;
    box-shadow:0 2px 8px rgba(201,162,78,.3);
  }
  .pf-cta{
    display:inline-flex;align-items:center;gap:10px;margin-top:24px;
    font-family:'Noto Sans JP',sans-serif;font-size:12px;letter-spacing:.15em;
    color:var(--gold);font-weight:600;padding:11px 22px;
    border:1px solid var(--gold);background:transparent;
    transition:.25s;text-decoration:none;
  }
  .pf-cta:hover{background:var(--gold);color:var(--navy)}
  .pf-cta::after{
    content:"→";font-family:'Cormorant Garamond',serif;font-size:18px;
    transition:transform .2s;line-height:1;
  }
  .pf-cta:hover::after{transform:translateX(4px)}

  /* ===== Pricing ===== */
  .pricing{background:var(--ivory)}
  .pricing-callout{
    background:linear-gradient(135deg,#B8472E 0%,#D85838 100%);
    color:#fff;padding:60px 40px;margin-bottom:64px;text-align:center;
    position:relative;overflow:hidden;
  }
  .pricing-callout::before{
    content:"";position:absolute;inset:14px;border:1px solid rgba(255,255,255,.25);
  }
  .pricing-callout-inner{position:relative;z-index:1}
  .pricing-callout .campaign-badge{
    display:inline-block;background:#fff;color:#B8472E;
    padding:7px 24px;font-size:11px;letter-spacing:.35em;font-weight:600;margin-bottom:24px;
  }
  .pricing-callout h3{
    font-size:38px;color:#fff;margin-bottom:18px;font-weight:500;letter-spacing:.15em;
  }
  .pricing-callout h3 .big{
    font-family:'Cormorant Garamond',serif;font-size:90px;color:#FFE5C2;
    font-weight:400;letter-spacing:.04em;vertical-align:-14px;
  }
  .pricing-callout p{
    color:rgba(255,255,255,.95);font-size:14px;line-height:2;font-weight:300;letter-spacing:.08em;
  }
  .pricing-callout p strong{color:#FFE5C2;font-weight:500}

  .plan-section{margin-bottom:64px}
  .plan-section-title{
    font-size:24px;margin-bottom:32px;padding-bottom:18px;color:var(--navy);
    border-bottom:1px solid var(--gold);font-weight:500;letter-spacing:.12em;
    display:flex;align-items:center;gap:14px;
  }
  .plan-section-title small{
    font-family:'Italiana',serif;font-size:11px;letter-spacing:.35em;
    color:var(--gold-deep);font-weight:400;
  }
  @media (max-width:768px){
    .plan-section-title{
      flex-direction:column;align-items:flex-start;gap:8px;
      font-size:20px;margin-bottom:24px;padding-bottom:14px;letter-spacing:.08em;
    }
    .plan-section-title small{
      font-size:10px;letter-spacing:.25em;line-height:1.7;display:block;
    }
  }
  .plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  @media (max-width:980px){.plan-grid{grid-template-columns:1fr}}
  .plan-card{
    background:var(--white);border:1px solid var(--ivory-deep);
    padding:36px 36px;transition:.3s;position:relative;
  }
  .plan-card:hover{border-color:var(--gold);box-shadow:var(--shadow)}
  .plan-card.featured{border:1px solid var(--gold);background:linear-gradient(135deg,#fff 0%,#FCF7EC 100%)}
  .plan-card.featured::before{
    content:"POPULAR";position:absolute;top:-12px;left:30px;
    background:var(--gold);color:var(--navy);
    padding:5px 16px;font-size:10px;letter-spacing:.3em;font-weight:600;font-family:'Noto Sans JP',sans-serif;
  }
  .plan-header{
    display:flex;justify-content:space-between;align-items:flex-start;
    gap:24px;flex-wrap:wrap;margin-bottom:20px;
  }
  .plan-name{
    font-size:22px;font-weight:500;color:var(--navy);letter-spacing:.1em;line-height:1.5;
  }
  .plan-name small{
    display:block;font-family:'Italiana',serif;font-size:10px;letter-spacing:.4em;
    color:var(--gold-deep);margin-top:4px;font-weight:400;
  }
  .plan-price{text-align:right;flex-shrink:0}
  .plan-price-original{
    color:var(--gray-soft);text-decoration:line-through;font-size:12px;
    font-family:'Cormorant Garamond',serif;display:block;margin-bottom:2px;
  }
  .plan-price-hp{
    color:#B8472E;font-weight:600;font-size:30px;
    font-family:'Cormorant Garamond',serif;letter-spacing:.02em;line-height:1;
  }
  .plan-price-hp small{font-size:14px;color:var(--ink-soft);font-weight:400;letter-spacing:.05em;margin-left:4px}
  .plan-desc{
    color:var(--ink-soft);font-size:13.5px;line-height:2.2;font-weight:300;letter-spacing:.05em;
    margin-bottom:20px;padding-bottom:20px;border-bottom:1px dashed var(--ivory-deep);
  }
  .plan-features-title{
    font-size:11px;letter-spacing:.3em;color:var(--gold-deep);
    font-family:'Italiana',serif;margin-bottom:14px;
  }
  .plan-features{list-style:none}
  .plan-features li{
    font-size:13px;color:var(--ink-soft);padding:8px 0 8px 24px;position:relative;
    line-height:1.8;font-weight:300;letter-spacing:.05em;
  }
  .plan-features li::before{
    content:"✓";position:absolute;left:0;top:8px;color:var(--gold);font-weight:700;
  }
  .plan-meta{
    display:flex;gap:24px;margin-top:20px;padding-top:20px;
    border-top:1px dashed var(--ivory-deep);font-size:12px;color:var(--ink-soft);
    letter-spacing:.05em;flex-wrap:wrap;
  }
  .plan-meta strong{color:var(--gold-deep);font-weight:500;margin-right:6px}

  /* Options table */
  .options-table{
    width:100%;border-collapse:separate;border-spacing:0;background:var(--white);
    box-shadow:var(--shadow);
  }
  .options-table th,.options-table td{
    padding:18px 24px;text-align:left;border-bottom:1px solid var(--ivory-deep);font-size:13.5px;
  }
  .options-table th{
    background:var(--cream);font-weight:500;color:var(--navy);
    font-size:11px;letter-spacing:.18em;
  }
  .options-table tr:last-child td{border-bottom:none}
  .options-table .opt-price{
    color:#B8472E;font-weight:600;font-size:18px;font-family:'Cormorant Garamond',serif;
  }
  .options-table .opt-original{
    color:var(--gray-soft);text-decoration:line-through;font-size:11px;
    font-family:'Cormorant Garamond',serif;display:block;
  }

  /* ===== Voices ===== */
  .voices{background:var(--cream)}
  .voice-categories{display:grid;gap:64px;margin-top:60px}
  .voice-cat-title{
    font-size:22px;margin-bottom:28px;color:var(--navy);font-weight:500;letter-spacing:.12em;
    display:flex;align-items:center;gap:18px;
  }
  .voice-cat-title::before{content:"";flex:0 0 4px;width:4px;height:28px;background:var(--gold)}
  .voice-cat-title small{
    font-family:'Italiana',serif;font-size:11px;letter-spacing:.4em;color:var(--gold-deep);font-weight:400;
  }
  .voice-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
  .voice-card{
    background:var(--white);padding:36px 28px;border:1px solid var(--ivory-deep);
    position:relative;transition:.3s;
  }
  .voice-card:hover{border-color:var(--gold)}
  .voice-card::before{
    content:"\201C";position:absolute;top:4px;left:18px;font-size:64px;color:var(--gold);opacity:.4;
    font-family:'Shippori Mincho B1',serif;line-height:1;
  }
  .voice-text{
    position:relative;z-index:1;color:var(--ink);font-size:13.5px;line-height:2.2;
    margin-bottom:20px;font-weight:300;letter-spacing:.05em;
  }
  .voice-meta{
    font-size:11px;color:var(--ink-soft);border-top:1px solid var(--ivory-deep);
    padding-top:14px;letter-spacing:.05em;
  }
  .voice-meta strong{
    color:var(--gold-deep);font-weight:500;display:block;margin-bottom:4px;
    font-size:12px;letter-spacing:.1em;
  }

  /* ===== FAQ ===== */
  .faq{background:var(--ivory)}
  .faq-list{max-width:800px;margin:60px auto 0}
  .faq-item{
    background:var(--white);margin-bottom:14px;border:1px solid var(--ivory-deep);transition:.3s;
  }
  .faq-item:hover{border-color:var(--gold)}
  .faq-q{
    padding:24px 32px;cursor:pointer;font-size:15px;color:var(--navy);font-weight:500;
    display:flex;align-items:center;gap:18px;letter-spacing:.05em;
    user-select:none;
  }
  .faq-q::before{
    content:"Q";font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--gold);
    font-weight:600;line-height:1;flex-shrink:0;
  }
  .faq-q::after{
    content:"+";margin-left:auto;color:var(--gold);font-size:24px;
    font-weight:300;transition:.3s;line-height:1;
  }
  .faq-item.open .faq-q::after{transform:rotate(45deg)}
  .faq-a{
    max-height:0;overflow:hidden;transition:max-height .4s ease;
    padding:0 32px;
  }
  .faq-item.open .faq-a{max-height:500px;padding-bottom:24px}
  .faq-a-inner{
    padding:0 0 0 38px;color:var(--ink-soft);font-size:13.5px;line-height:2.2;
    font-weight:300;letter-spacing:.05em;border-top:1px solid var(--ivory-deep);padding-top:20px;
  }
  .faq-a-inner::before{
    content:"A";font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--rose-accent);
    font-weight:600;margin-right:14px;line-height:1;float:left;margin-top:-2px;
  }

  /* ===== About ===== */
  .about{background:var(--navy);color:var(--ivory);padding:120px 0;position:relative}
  .about::before{
    content:"";position:absolute;top:40px;left:50%;transform:translateX(-50%);
    width:1px;height:60px;background:var(--gold);
  }
  .about-inner{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:center}
  .about-photo{
    aspect-ratio:4/5;border:1px solid var(--gold);overflow:hidden;position:relative;
    box-shadow:var(--shadow-gold);
  }
  .about-photo img{width:100%;height:100%;object-fit:cover}
  .about-photo::after{
    content:"";position:absolute;inset:14px;border:1px solid rgba(201,162,78,.4);pointer-events:none;
  }
  .about-eyebrow{
    font-family:'Italiana',serif;font-size:12px;letter-spacing:.5em;color:var(--gold);
    margin-bottom:16px;display:block;
  }
  .about-inner h2{
    font-size:34px;margin-bottom:32px;font-weight:500;letter-spacing:.12em;color:#fff;
  }
  .about-text{
    color:rgba(246,242,234,.85);font-size:14.5px;line-height:2.4;margin-bottom:20px;
    font-weight:300;letter-spacing:.05em;
  }
  .about-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:32px}
  .about-fact{
    background:rgba(201,162,78,.08);border:1px solid rgba(201,162,78,.3);
    padding:18px 22px;font-size:13px;color:var(--ivory);font-weight:300;letter-spacing:.05em;
  }
  .about-fact strong{
    color:var(--gold);font-weight:500;font-family:'Cormorant Garamond',serif;
    font-size:20px;letter-spacing:.04em;display:inline-block;margin-right:6px;
  }

  /* ===== Final CTA ===== */
  .cta-final{
    background:linear-gradient(135deg,var(--cream) 0%,var(--ivory-deep) 100%);
    text-align:center;padding:120px 0;position:relative;overflow:hidden;
  }
  .cta-final::before{
    content:"";position:absolute;top:60px;left:50%;transform:translateX(-50%);
    width:1px;height:40px;background:var(--gold);
  }
  .cta-final-campaign{
    display:inline-block;background:#B8472E;color:#fff;
    padding:9px 30px;font-size:11px;letter-spacing:.35em;font-weight:600;margin-bottom:32px;
  }
  .cta-final h2{
    font-size:38px;margin-bottom:24px;font-weight:500;letter-spacing:.12em;line-height:1.7;color:var(--navy);
  }
  .cta-final p{
    font-size:15px;margin-bottom:48px;color:var(--ink-soft);line-height:2.2;
    font-weight:300;letter-spacing:.06em;
  }
  .btn-line-large{
    background:var(--line-green);color:#fff;font-size:15px;padding:24px 56px;
    box-shadow:0 14px 40px rgba(6,199,85,.3);
  }
  .btn-line-large:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(6,199,85,.45)}
  .cta-note{
    font-size:12px;color:var(--ink-soft);margin-top:32px;letter-spacing:.08em;font-weight:300;line-height:2;
  }

  /* ===== Footer ===== */
  footer{
    background:var(--navy);color:rgba(246,242,234,.6);padding:48px 0 32px;
    text-align:center;border-top:1px solid rgba(201,162,78,.15);font-size:12px;letter-spacing:.08em;
  }
  footer .logo{color:#fff;margin-bottom:12px;display:inline-block}
  footer p{font-size:11px;line-height:2;font-weight:300}

  /* ===== Responsive helpers ===== */
  .sp-only{display:none}
  .nobr-sp{display:inline}
  @media (max-width: 860px){
    .pc-only{display:none}
    .sp-only{display:inline}
    .nobr-sp{display:inline-block}
  }

  /* ===== Responsive ===== */
  @media (max-width: 860px){
    .hero{padding:60px 0 80px}
    .hero-inner{grid-template-columns:1fr;gap:56px}
    .hero h1{font-size:26px;line-height:1.75;letter-spacing:.03em}
    .hero-visual{max-width:340px;margin:0 auto}
    section{padding:80px 0}
    .section-head h2{font-size:26px}
    .problems-grid,.reasons-grid{grid-template-columns:1fr;gap:20px}
    .reasons-grid{gap:48px}
    .portfolio-grid{grid-template-columns:1fr}
    .about-inner{grid-template-columns:1fr;gap:48px;text-align:center}
    .about-photo{max-width:280px;margin:0 auto}
    .about-facts{text-align:left}
    .cta-final h2{font-size:24px}
    .nav-links{display:none}
    .menu-toggle{display:flex}
    .nav{height:64px}
    .logo{font-size:20px}
    .nav-cta{padding:9px 16px;font-size:10px;letter-spacing:.18em}
    .pricing-callout h3{font-size:26px}
    .pricing-callout h3 .big{font-size:60px;vertical-align:-8px}
    .plan-card{padding:28px 24px}
    .plan-header{flex-direction:column;gap:12px}
    .plan-price{text-align:left}
    .plan-name{font-size:18px}
    .plan-price-hp{font-size:24px}
    .container{padding:0 20px}
    .faq-q{padding:18px 20px;font-size:13.5px;gap:14px}
    .faq-q::before{font-size:20px}
    .faq-item.open .faq-a{padding-bottom:18px}
    .faq-a{padding:0 20px}
    .faq-a-inner{padding-left:32px;font-size:13px}
  }


/* ===== Sub-page additions ===== */
.page-hero{background:var(--navy);color:var(--ivory);padding:116px 0 84px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:40px;right:60px;width:140px;height:140px;border:1px solid var(--gold);border-radius:50%;opacity:.25}
.page-hero::after{content:"";position:absolute;bottom:30px;left:40px;width:80px;height:80px;border:1px solid var(--gold);border-radius:50%;opacity:.18}
.page-hero .eyebrow{color:var(--gold)}
.page-hero h1{font-size:42px;color:var(--ivory);letter-spacing:.14em;margin-bottom:18px;font-weight:500;line-height:1.5;position:relative}
.page-hero p{color:rgba(246,242,234,.8);font-size:14.5px;font-weight:300;line-height:2.1;letter-spacing:.06em;max-width:680px;margin:0 auto;position:relative}
.breadcrumb{font-size:11px;letter-spacing:.12em;color:rgba(246,242,234,.6);margin-bottom:22px;position:relative}
.breadcrumb a{color:rgba(246,242,234,.75)}
.breadcrumb a:hover{color:var(--gold)}
.nav-links a.is-current{color:var(--gold);opacity:1}
@media (max-width:860px){.page-hero{padding:72px 0 56px}.page-hero h1{font-size:26px}}