/* PortExcellent — editorial almanac · cream/teal/coral/gold · zero-JS */
:root{
  --paper:#faf5ea;--card:#fffdf7;--cream-d:#f2ead6;--sand:#f6efdf;
  --ink:#3b4145;--head:#14404b;--muted:#78705d;
  --teal:#0e7488;--teal-d:#0a5766;--coral:#e35c47;--coral-d:#bf4634;
  --gold:#b98a2b;--gold-l:#e8cf9a;--line:#e6dcc3;
  --mint:#eaf4ef;--peach:#fbeee4;
  --sh:0 18px 40px -22px rgba(20,64,75,.28);--sh-sm:0 8px 22px -14px rgba(20,64,75,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Prompt',sans-serif;background:var(--paper);color:var(--ink);font-size:15.5px;line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Trirong',serif;color:var(--head);line-height:1.3;font-weight:700}
svg{width:1em;height:1em;vertical-align:-.13em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
b{font-weight:600}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Prompt',sans-serif;font-weight:600;font-size:15px;padding:12px 26px;border-radius:32px;border:none;cursor:pointer;transition:.18s}
.btn svg{width:17px;height:17px}
.btn-c{background:var(--coral);color:#fff;box-shadow:0 10px 24px -10px rgba(191,70,52,.5)}
.btn-c:hover{background:var(--coral-d);transform:translateY(-2px)}
.btn-o{background:transparent;color:var(--teal-d);border:1.5px solid var(--teal);border-radius:32px}
.btn-o:hover{background:var(--teal);color:#fff;transform:translateY(-2px)}
.btn-w{background:var(--card);color:var(--coral-d)}
.btn-w:hover{transform:translateY(-2px)}

/* header */
.nav{position:sticky;top:0;z-index:60;background:rgba(250,245,234,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:16px;height:62px}
.brand{font-family:'Trirong',serif;font-weight:700;font-size:20px;color:var(--head);display:flex;align-items:baseline;gap:9px;flex:0 0 auto}
.brand .dot{color:var(--coral)}
.brand small{font-family:'Prompt',sans-serif;font-size:9.5px;font-weight:600;letter-spacing:2.2px;color:var(--gold);text-transform:uppercase}
.nlinks{display:flex;gap:2px;font-size:13.5px;font-weight:500;margin-left:6px;overflow-x:auto;scrollbar-width:none}
.nlinks::-webkit-scrollbar{display:none}
.nlinks a{color:var(--muted);padding:7px 11px;border-radius:8px;white-space:nowrap;transition:.15s}
.nlinks a:hover{color:var(--head);background:var(--sand)}
.nlinks a.on{color:var(--teal-d);background:var(--card);box-shadow:var(--sh-sm)}
.nav .cta{margin-left:auto;flex:0 0 auto}.nav .cta .btn{padding:8px 17px;font-size:13px}
@media(max-width:760px){.nav .wrap{flex-wrap:wrap;height:auto;padding-top:9px;padding-bottom:9px}.nlinks{order:3;width:100%;margin-left:-4px}}

/* editorial hero (home) */
.hero{position:relative;padding:64px 0 56px;overflow:hidden;border-bottom:1px solid var(--line);
  background:
    radial-gradient(520px 300px at 88% -8%, rgba(227,92,71,.10), transparent 65%),
    radial-gradient(460px 320px at -6% 108%, rgba(14,116,136,.09), transparent 65%),
    repeating-linear-gradient(90deg, rgba(185,138,43,.05) 0 1px, transparent 1px 120px)}
.hero .kicker{margin-bottom:18px}
.hero h1{font-size:clamp(30px,5vw,52px);font-weight:700;max-width:820px}
.hero h1 em{font-style:normal;color:var(--coral-d);background:linear-gradient(transparent 68%,var(--gold-l) 68% 92%,transparent 92%)}
.hero .s{margin-top:18px;max-width:640px;font-size:17px;font-weight:300;color:var(--ink)}
.hero .cta-row{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.hero .facts{display:flex;gap:0;margin-top:36px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero .facts .f{padding:14px 26px 2px 0;margin-right:26px;border-right:1px solid var(--line)}
.hero .facts .f:last-child{border-right:none}
.hero .facts b{font-family:'Trirong',serif;font-size:19px;color:var(--teal-d);display:block}
.hero .facts span{font-size:12px;color:var(--muted)}

/* kicker + section heads */
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;letter-spacing:2.4px;text-transform:uppercase;color:var(--gold)}
.kicker::before{content:"";width:26px;height:1px;background:var(--gold)}
section{padding:52px 0}
.sec-head{margin-bottom:30px;max-width:720px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .kicker::after{content:"";width:26px;height:1px;background:var(--gold)}
.sec-head h2{font-size:clamp(24px,3.4vw,34px);margin-top:10px}
.sec-head p{color:var(--muted);margin-top:8px;font-weight:300}
.rule2{border:none;border-top:1px solid var(--line);position:relative;margin:0}
.rule2::after{content:"";position:absolute;top:2px;left:0;right:0;border-top:1px solid var(--line)}

/* grids & cards */
.grid{display:grid;gap:18px}
.c2{grid-template-columns:1fr 1fr}.c3{grid-template-columns:repeat(3,1fr)}.c4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px 24px;box-shadow:var(--sh-sm)}
.card.pad0{padding:0;overflow:hidden}
.card h3{font-size:19px;margin-bottom:8px}
.mint{background:var(--mint)}.peach{background:var(--peach)}.sand{background:var(--sand)}
.pill{display:inline-block;background:var(--sand);border:1px solid var(--line);border-radius:20px;padding:3px 12px;font-size:11.5px;margin:3px 5px 0 0;color:var(--muted)}
.hi{color:var(--coral-d);font-weight:600}
ul.clean{list-style:none;font-size:14px}
ul.clean li{position:relative;padding-left:19px;margin-bottom:7px}
ul.clean li::before{content:"";position:absolute;left:1px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
ul.warn li::before{background:var(--gold);border-radius:2px}

/* numbered method (01 02 03) */
.method{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--card)}
.method .m{padding:26px 26px 24px;border-right:1px solid var(--line)}
.method .m:last-child{border-right:none}
.method .no{font-family:'Trirong',serif;font-size:38px;font-weight:600;color:var(--gold);line-height:1}
.method h3{font-size:19px;margin:12px 0 8px}
.method p{font-size:13.5px;color:var(--muted);font-weight:300}
@media(max-width:820px){.method{grid-template-columns:1fr}.method .m{border-right:none;border-bottom:1px solid var(--line)}.method .m:last-child{border-bottom:none}}

/* link cards */
.linkcard{display:flex;flex-direction:column;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-sm);transition:.2s}
.linkcard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.linkcard .pic{aspect-ratio:16/9;position:relative;background:var(--cream-d)}
.linkcard .bd{padding:16px 19px;flex:1;display:flex;flex-direction:column}
.linkcard h3{font-size:18px}
.linkcard p{font-size:13px;color:var(--muted);font-weight:300;margin-top:5px;flex:1}
.linkcard .go{margin-top:12px;font-size:13px;font-weight:600;color:var(--coral-d);display:flex;align-items:center;gap:6px}
.linkcard .go svg{width:15px;height:15px}

/* page head (subpages) */
.phead{padding:44px 0 34px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--sand),var(--paper))}
.phead h1{font-size:clamp(26px,3.8vw,40px);max-width:840px}
.phead p{color:var(--muted);font-weight:300;margin-top:9px;max-width:700px}
.crumb{font-size:12px;color:var(--muted);margin-bottom:14px}
.crumb a{color:var(--gold)}

/* steps (service) */
.step{display:grid;grid-template-columns:70px 1fr;gap:20px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 26px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.step .n{font-family:'Trirong',serif;font-size:40px;font-weight:600;color:var(--gold);line-height:1;padding-top:2px}
.step h3{font-size:20px;margin-bottom:8px}
.step ul{margin:6px 0 0;padding-left:18px}.step li{margin:.35em 0;font-size:14px}
@media(max-width:620px){.step{grid-template-columns:1fr}}

/* timeline strip */
.tl{display:flex;flex-wrap:wrap;gap:10px}
.tl .t{flex:1;min-width:160px;background:var(--card);border:1px solid var(--line);border-top:3px solid var(--teal);border-radius:11px;padding:13px 15px}
.tl .t b{color:var(--teal-d);font-size:13.5px}.tl .t span{display:block;font-size:12.5px;color:var(--muted);margin-top:3px}
.tl .t.now{border-top-color:var(--coral)}.tl .t.now b{color:var(--coral-d)}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split .pic{aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.gallery .g{aspect-ratio:4/3;border-radius:11px;overflow:hidden;border:1px solid var(--line)}

/* table */
table{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
th{background:var(--head);color:#f6efdf;font-weight:500;font-size:12.5px;font-family:'Prompt',sans-serif}
tr:last-child td{border-bottom:none}
tr:nth-child(even) td{background:var(--sand)}
.code{font-weight:700;color:var(--coral-d)}.price{font-weight:700;color:var(--teal-d);white-space:nowrap}

/* ladder */
.ladder{display:grid;grid-template-columns:repeat(4,1fr)}
.lstep{padding:17px 16px;background:var(--card);border:1px solid var(--line);border-right:none;position:relative}
.lstep:first-child{border-radius:12px 0 0 12px}.lstep:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0}
.lstep .bar{height:4px;border-radius:4px;margin-bottom:11px}
.b0{background:var(--gold-l)}.b1{background:var(--teal)}.b2{background:var(--coral)}.b3{background:var(--gold)}
.lstep .t{font-weight:700;color:var(--head);font-size:14.5px;font-family:'Trirong',serif}
.lstep .g{font-size:11.5px;color:var(--muted)}.lstep .p{font-weight:600;color:var(--coral-d);font-size:12.5px;margin-top:7px}
.core{position:absolute;top:-9px;right:9px;background:var(--coral);color:#fff;font-size:9.5px;font-weight:600;padding:2px 8px;border-radius:6px}
@media(max-width:860px){.ladder{grid-template-columns:1fr 1fr}.lstep{border:1px solid var(--line);border-radius:10px!important;margin:-1px 0 0 -1px}}

/* day schedule */
.days{display:flex;flex-direction:column;gap:8px}
.day{display:grid;grid-template-columns:84px 1fr;gap:12px;background:var(--sand);border:1px solid var(--line);border-radius:10px;padding:10px 13px;font-size:13px}
.day .d{font-weight:700;color:var(--teal-d);font-size:12.5px}

/* QA */
.qa{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:19px 22px;margin-bottom:12px;box-shadow:var(--sh-sm)}
.qa h3{font-size:17px;margin:0 0 7px;display:flex;gap:10px;align-items:flex-start}
.qa h3 .q{font-family:'Trirong',serif;color:var(--gold);flex:0 0 auto;font-size:19px}
.qa p{margin:0;font-size:14px}
.ethic{background:var(--sand);border:1px solid var(--gold-l);border-left:4px solid var(--gold);border-radius:12px;padding:20px 24px;margin-top:22px}
.ethic h2{font-size:20px;margin:0 0 8px;color:#7c5c14}
.ethic ul{margin:6px 0 0;padding-left:18px;font-size:14px}.ethic li{margin:.35em 0}

/* CTA band */
.cta-band{background:var(--head);color:#f6efdf;border:1px solid var(--teal-d);outline:1px solid var(--gold-l);outline-offset:4px;border-radius:20px;padding:44px 40px;text-align:center;box-shadow:var(--sh);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 220px at 85% 0%,rgba(227,92,71,.22),transparent 65%)}
.cta-band h2{color:#fdf9ef;font-size:clamp(22px,3vw,30px);position:relative}
.cta-band p{margin:10px auto 22px;max-width:540px;opacity:.85;font-weight:300;position:relative}
.cta-band .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

/* disclaimer + footer */
.disclaimer-band{background:var(--peach);border-top:1px solid #eed4c4;color:#7c4030;font-size:13px;padding:12px 0}
.disclaimer-band .wrap{display:flex;align-items:flex-start;gap:9px;line-height:1.6}
.disclaimer-band .ic{color:var(--coral-d);flex:0 0 auto;margin-top:1px}
.disclaimer-band b{color:var(--coral-d)}
footer.ft{background:var(--head);color:#c8d8d2;padding:34px 0 26px}
footer.ft .cols{display:flex;justify-content:space-between;gap:22px;flex-wrap:wrap}
footer.ft .fbrand{font-family:'Trirong',serif;color:#fdf9ef;font-weight:700;font-size:19px}
footer.ft .fbrand small{display:block;font-family:'Prompt',sans-serif;font-size:9.5px;letter-spacing:2.2px;color:var(--gold-l);text-transform:uppercase;margin-top:3px}
footer.ft a{color:#a9c4bd}footer.ft a:hover{color:#fff}
footer.ft .fl{display:flex;flex-direction:column;gap:6px;font-size:13.5px}
footer.ft .fl b{color:#fdf9ef;font-weight:600}
footer.ft .note{color:#7fa39a;font-size:11.5px;margin-top:18px;border-top:1px solid rgba(246,239,223,.15);padding-top:12px}

/* forms */
input,select,textarea{font-family:'Prompt',sans-serif;font-size:14px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 13px;outline:none;color:var(--ink);width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--teal)}

@media(max-width:860px){.c2,.c3,.c4,.split,.gallery{grid-template-columns:1fr}.split.rev{direction:ltr}section{padding:40px 0}}
@media(min-width:861px) and (max-width:1040px){.c4{grid-template-columns:repeat(2,1fr)}}
