:root{
  --navy-1:#314066;
  --navy-2:#1a2338;
  --navy-3:#071536;
  --navy-hover:#243156;
  --white:#ffffff;
  --g50:#f8fafc;
  --g100:#eef2f7;
  --g200:#dfe6ef;
  --g300:#cbd5e1;
  --g400:#94a3b8;
  --g500:#64748b;
  --g600:#475569;
  --g700:#334155;
  --g900:#0f172a;
  --border:#e6ebf2;
  --soft-shadow: 0 1px 2px rgba(15,23,42,.04), 0 8px 24px rgba(15,23,42,.05);
  --card-shadow: 0 1px 2px rgba(15,23,42,.04), 0 12px 40px rgba(15,23,42,.06);
  --radius-sm:10px;
  --radius-md:14px;
  --radius-lg:20px;
  --radius-xl:28px;
  --container:1240px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--white);color:var(--navy-3);font-family:'Inter','Noto Sans KR','Noto Sans JP',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:15px;line-height:1.55}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img,svg{display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.h-only-mobile{display:none}

/* ---- Util bar ---- */
.utilbar{background:var(--navy-3);color:rgba(255,255,255,.85);font-size:12.5px}
.utilbar .row{display:flex;justify-content:space-between;align-items:center;height:36px}
.utilbar a,.utilbar button{display:inline-flex;align-items:center;gap:6px;padding:0 14px;color:rgba(255,255,255,.78);transition:color .15s;background:transparent;border:none;font-size:12.5px;height:36px;cursor:pointer}
.utilbar a:hover,.utilbar button:hover{color:#fff}
.utilbar .left{display:flex;align-items:center;margin-left:-14px}
.utilbar .right{display:flex;align-items:center;margin-right:-14px}
.utilbar .right a.join{color:#fff;font-weight:500}
.utilbar .sep{width:1px;height:11px;background:rgba(255,255,255,.16)}
.utilbar .lang-btn .caret{width:10px;height:10px}

/* ---- Header ---- */
.header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.header .row{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:30px;width:auto;display:block}
nav.main-nav{display:flex;gap:6px}
nav.main-nav a{position:relative;padding:10px 18px;font-size:15px;font-weight:500;color:var(--navy-2);letter-spacing:.005em;border-radius:8px;transition:all .15s}
nav.main-nav a:hover{color:var(--navy-1);background:var(--g50)}
nav.main-nav a.active{color:var(--navy-1)}
nav.main-nav a.active::after{content:"";position:absolute;left:18px;right:18px;bottom:-26px;height:2px;background:var(--navy-1);border-radius:2px}
.head-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.icon-btn{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--navy-2);transition:background .15s}
.icon-btn:hover{background:var(--g100)}
.mypage-btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--navy-2);font-weight:500;font-size:14px;transition:all .15s}
.mypage-btn:hover{border-color:var(--navy-1);color:var(--navy-1)}
.hamburger{display:none}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;background:#fafbfc}
.hero .wave-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;z-index:0}
.hero .container{position:relative;z-index:1;padding-top:96px;padding-bottom:130px}
.hero h1{font-size:64px;line-height:1.08;letter-spacing:-.025em;font-weight:700;color:var(--navy-3);margin:0 0 22px;max-width:760px;text-wrap:balance}
.hero .sub{font-size:17px;color:var(--g600);max-width:540px;margin:0 0 36px;line-height:1.55}
.hero .sub strong{color:var(--navy-2);font-weight:500}
.cta{display:inline-flex;align-items:center;gap:10px;height:54px;padding:0 28px;background:var(--navy-1);color:#fff;border-radius:999px;font-size:15px;font-weight:600;border:none;letter-spacing:.01em;transition:background .15s,transform .15s}
.cta:hover{background:var(--navy-hover)}
.cta svg{transition:transform .2s}
.cta:hover svg{transform:translateX(3px)}

/* small page hero (sub-pages) */
.page-hero{position:relative;overflow:hidden;background:#fafbfc;border-bottom:1px solid var(--border)}
.page-hero .wave-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;opacity:.9}
.page-hero .container{position:relative;z-index:1;padding-top:64px;padding-bottom:64px}
.page-hero .eyebrow{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--navy-1);margin-bottom:12px}
.page-hero h1{font-size:44px;line-height:1.12;letter-spacing:-.02em;font-weight:700;color:var(--navy-3);margin:0 0 14px}
.page-hero p{font-size:16px;color:var(--g600);margin:0;max-width:600px}

/* ---- Notice banner ---- */
.notice-wrap{position:relative;z-index:2;margin-top:-32px}
.notice{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 20px;box-shadow:var(--soft-shadow)}
.notice .badge{display:inline-flex;align-items:center;gap:6px;background:var(--navy-1);color:#fff;height:28px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.04em}
.notice .msg{flex:1;font-size:14.5px;color:var(--navy-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.notice .msg .date{color:var(--g500);margin-left:10px;font-size:13px}
.notice .right{display:flex;align-items:center;gap:4px;color:var(--g600);flex-shrink:0}
.notice .view-all{font-size:13px;color:var(--g600);padding:6px 10px;border-radius:6px}
.notice .view-all:hover{background:var(--g50);color:var(--navy-2)}
.notice .arrow{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--navy-2);display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.notice .arrow:hover{border-color:var(--navy-1);color:var(--navy-1)}

/* ---- Booking card ---- */
.booking-wrap{position:relative;z-index:2;margin-top:18px;padding-bottom:80px}
.booking{background:#fff;border:1px solid var(--border);border-radius:24px;box-shadow:var(--card-shadow);overflow:hidden}
.b-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--g50)}
.b-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px;height:64px;background:transparent;border:none;color:var(--g600);font-size:15px;font-weight:500;border-right:1px solid var(--border);position:relative;transition:all .15s}
.b-tab:last-child{border-right:none}
.b-tab svg{width:18px;height:18px;stroke:currentColor}
.b-tab:hover{color:var(--navy-2);background:#fff}
.b-tab.active{background:var(--navy-1);color:#fff;font-weight:600}
.b-tab.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--navy-1)}
.b-body{padding:24px 28px 28px}
.b-types{display:flex;gap:24px;margin-bottom:18px;flex-wrap:wrap}
.radio{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--g600);user-select:none;position:relative}
.radio input{position:absolute;opacity:0;pointer-events:none}
.radio .dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--g300);display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.radio .dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--navy-1);transform:scale(0);transition:transform .15s}
.radio input:checked + .dot{border-color:var(--navy-1)}
.radio input:checked + .dot::after{transform:scale(1)}
.radio input:checked ~ .lbl{color:var(--navy-2);font-weight:500}

.b-form{display:grid;grid-template-columns:1.5fr 1.5fr 1fr 1fr 1fr auto;gap:0;border:1px solid var(--border);border-radius:16px;overflow:hidden}
.field{padding:14px 18px;border-right:1px solid var(--border);position:relative;cursor:pointer;transition:background .15s}
.field:hover{background:var(--g50)}
.field.active{background:#fff;box-shadow:inset 0 0 0 2px var(--navy-1);border-radius:14px;border-right-color:transparent;z-index:1}
.field .label{font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--g500);font-weight:600;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.field .val{display:flex;align-items:baseline;gap:10px}
.field .code{font-size:26px;font-weight:700;color:var(--navy-3);letter-spacing:-.01em;line-height:1}
.field .city{font-size:13px;color:var(--g500)}
.field .single{font-size:18px;font-weight:600;color:var(--navy-2);line-height:1.2}
.field .single small{display:block;font-size:12px;font-weight:500;color:var(--g500);margin-top:2px}
.field .chev{color:var(--g400)}
.swap{position:absolute;right:-18px;top:50%;transform:translateY(-50%);z-index:2;width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--border);color:var(--navy-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;box-shadow:0 2px 8px rgba(15,23,42,.06)}
.swap:hover{border-color:var(--navy-1);color:var(--navy-1);transform:translateY(-50%) rotate(180deg)}
.field.from{padding-right:30px}
.search-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 36px;background:var(--navy-1);color:#fff;border:none;font-size:15px;font-weight:600;letter-spacing:.01em;transition:background .15s;min-width:200px}
.search-btn:hover{background:var(--navy-hover)}
.search-btn:disabled{opacity:.7;cursor:default}
.search-btn svg{transition:transform .2s}
.search-btn:hover svg{transform:translateX(3px)}

.b-extras{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.b-extra{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--g600);padding:6px 12px;border-radius:999px;background:var(--g50);cursor:pointer;transition:all .15s}
.b-extra:hover{background:var(--g100);color:var(--navy-2)}
.b-extra svg{width:14px;height:14px}

/* ---- Generic sections ---- */
.section{padding:80px 0}
.section.tight{padding:60px 0}
.grid-two{display:grid;grid-template-columns:1.1fr 1.9fr;gap:24px}
.promo{background:linear-gradient(135deg,var(--navy-2),var(--navy-1));color:#fff;border-radius:24px;padding:36px;position:relative;overflow:hidden;min-height:380px;display:flex;flex-direction:column;justify-content:space-between}
.promo::after{content:"";position:absolute;right:-80px;bottom:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 70%);pointer-events:none}
.promo .eyebrow{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:14px}
.promo h2{font-size:36px;line-height:1.15;font-weight:700;margin:0 0 16px;letter-spacing:-.02em}
.promo p{font-size:14.5px;color:rgba(255,255,255,.78);margin:0 0 24px;max-width:300px}
.promo .meta{display:flex;align-items:flex-end;justify-content:space-between;position:relative;z-index:1}
.promo .price{font-size:14px;color:rgba(255,255,255,.7)}
.promo .price strong{display:block;font-size:32px;font-weight:700;color:#fff;letter-spacing:-.01em;margin-top:4px}
.promo .book-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--navy-2);height:46px;padding:0 22px;border-radius:999px;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:transform .15s}
.promo .book-btn:hover{transform:translateY(-2px)}

.shortcuts{background:#fff;border:1px solid var(--border);border-radius:24px;padding:32px 36px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}
.sec-head .title{font-size:22px;font-weight:700;color:var(--navy-3);margin:0;letter-spacing:-.01em}
.sec-head .sub{font-size:13.5px;color:var(--g500);margin-top:4px;font-weight:400}
.sec-head .link{font-size:13px;color:var(--g600);display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.sec-head .link:hover{color:var(--navy-1)}
.shortcut-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.sc{display:flex;flex-direction:column;align-items:center;gap:10px;padding:22px 12px;border-radius:14px;color:var(--navy-2);transition:background .15s;cursor:pointer;text-align:center}
.sc:hover{background:var(--g50)}
.sc .ico{width:52px;height:52px;border-radius:14px;background:var(--g50);display:inline-flex;align-items:center;justify-content:center;color:var(--navy-1);transition:all .15s}
.sc:hover .ico{background:var(--navy-1);color:#fff}
.sc .lbl{font-size:13px;font-weight:500;color:var(--navy-2)}

.notice-list-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:32px 36px}
.nl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 32px}
.nl-item{padding:20px 0;border-top:1px solid var(--border)}
.nl-item:first-child,.nl-item:nth-child(2),.nl-item:nth-child(3){border-top:none;padding-top:0}
.nl-item .tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--navy-1);background:var(--g50);padding:4px 10px;border-radius:999px;margin-bottom:10px;text-transform:uppercase}
.nl-item h4{font-size:15px;font-weight:600;color:var(--navy-2);margin:0 0 8px;line-height:1.4;letter-spacing:-.005em}
.nl-item .date{font-size:12.5px;color:var(--g500)}

/* ---- Footer ---- */
footer{background:var(--navy-3);color:rgba(255,255,255,.7);padding:56px 0 32px;font-size:13px}
footer .grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:32px;margin-bottom:40px}
footer h5{color:#fff;font-size:13px;font-weight:600;letter-spacing:.04em;margin:0 0 14px;text-transform:uppercase}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
footer ul a{color:rgba(255,255,255,.65);font-size:13px}
footer ul a:hover{color:#fff}
footer .brandcol img{height:32px;width:auto;filter:brightness(0) invert(1)}
footer .brandcol p{color:rgba(255,255,255,.5);font-size:12.5px;line-height:1.6;margin:16px 0 0;max-width:260px}
footer .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.45);gap:16px;flex-wrap:wrap}
footer .bottom .links{display:flex;gap:18px}

/* ---- Language modal ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(7,21,54,.55);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{background:#fff;border-radius:20px;padding:32px;max-width:440px;width:100%;box-shadow:0 20px 80px rgba(7,21,54,.4);transform:translateY(10px);transition:transform .25s;border:1px solid var(--border)}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.modal-head h3{margin:0;font-size:20px;font-weight:700;color:var(--navy-3);letter-spacing:-.01em}
.modal-head p{margin:4px 0 0;font-size:13px;color:var(--g500)}
.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--g50);color:var(--navy-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.modal-close:hover{background:var(--g100)}
.lang-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.lang-option{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:1.5px solid var(--border);background:#fff;cursor:pointer;transition:all .15s;text-align:left;width:100%}
.lang-option:hover{border-color:var(--navy-1);background:var(--g50)}
.lang-option.selected{border-color:var(--navy-1);background:#f3f6fb}
.lang-option .flag{width:36px;height:36px;border-radius:50%;background:var(--g100);display:inline-flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;overflow:hidden}
.lang-option .info{flex:1}
.lang-option .info .name{font-weight:600;color:var(--navy-2);font-size:15px}
.lang-option .info .native{font-size:12.5px;color:var(--g500);margin-top:2px}
.lang-option .check{color:var(--navy-1);opacity:0}
.lang-option.selected .check{opacity:1}

/* ---- Mobile drawer ---- */
.drawer-overlay{position:fixed;inset:0;background:rgba(7,21,54,.4);z-index:998;opacity:0;pointer-events:none;transition:opacity .2s}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:90%;background:#fff;z-index:999;transform:translateX(100%);transition:transform .25s;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}
.drawer-head img{height:24px}
.drawer-nav{padding:16px 8px;flex:1;overflow:auto}
.drawer-nav a{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;color:var(--navy-2);font-size:16px;font-weight:500;border-radius:10px}
.drawer-nav a:hover{background:var(--g50)}
.drawer-nav a.active{color:var(--navy-1);background:var(--g50)}
.drawer-foot{padding:18px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.drawer-foot button{height:44px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--navy-2);font-size:14px;font-weight:500;cursor:pointer}
.drawer-foot button.primary{background:var(--navy-1);color:#fff;border-color:var(--navy-1)}

/* ============== Page-specific ============== */

/* shared image placeholder w/ subtle stripes */
.img-ph{position:relative;background:linear-gradient(135deg,#e9eef5,#d9e1ea);overflow:hidden;border-radius:14px}
.img-ph::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.35) 0 1px,transparent 1px 14px);pointer-events:none}
.img-ph .ph-label{position:absolute;left:14px;bottom:12px;font-family:'JetBrains Mono','SF Mono',ui-monospace,Menlo,monospace;font-size:11px;color:var(--g600);background:rgba(255,255,255,.7);padding:3px 8px;border-radius:6px;letter-spacing:.04em}

/* ---- Destinations / route cards ---- */
.dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.dest-card{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:all .2s;cursor:pointer;display:flex;flex-direction:column}
.dest-card:hover{transform:translateY(-3px);box-shadow:var(--card-shadow);border-color:#dbe2ec}
.dest-card .img-ph{height:200px;border-radius:0}
.dest-card .body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:6px}
.dest-card .route{font-size:11.5px;color:var(--g500);font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.dest-card .city{font-size:20px;font-weight:700;color:var(--navy-3);letter-spacing:-.01em;margin:2px 0 4px}
.dest-card .meta{display:flex;justify-content:space-between;align-items:flex-end;margin-top:10px}
.dest-card .meta .from{font-size:12px;color:var(--g500)}
.dest-card .meta .price{font-size:20px;font-weight:700;color:var(--navy-1);letter-spacing:-.01em}

/* ---- Flight result row (booking page) ---- */
.results{display:flex;flex-direction:column;gap:12px}
.flight-row{background:#fff;border:1px solid var(--border);border-radius:18px;padding:20px 24px;display:grid;grid-template-columns:auto 1fr auto auto;gap:24px;align-items:center;transition:all .15s}
.flight-row:hover{border-color:var(--navy-1);box-shadow:var(--soft-shadow)}
.flight-row .airline{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:80px}
.flight-row .airline .logo{width:36px;height:36px;border-radius:10px;background:var(--navy-2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;letter-spacing:.04em}
.flight-row .airline .num{font-size:11.5px;color:var(--g500);font-weight:500}
.flight-row .timeline{display:flex;align-items:center;gap:16px}
.flight-row .point{display:flex;flex-direction:column;align-items:center;min-width:60px}
.flight-row .point .time{font-size:22px;font-weight:700;color:var(--navy-3);letter-spacing:-.01em;line-height:1.1}
.flight-row .point .code{font-size:12px;color:var(--g500);margin-top:2px;letter-spacing:.04em}
.flight-row .duration{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:120px}
.flight-row .duration .line{position:relative;width:100%;height:1px;background:var(--g300)}
.flight-row .duration .line::before,.flight-row .duration .line::after{content:"";position:absolute;top:-2px;width:5px;height:5px;border-radius:50%;background:var(--navy-1)}
.flight-row .duration .line::before{left:0}
.flight-row .duration .line::after{right:0}
.flight-row .duration .dur{font-size:12px;color:var(--g500);font-weight:500}
.flight-row .duration .stops{font-size:11px;color:var(--g400);text-transform:uppercase;letter-spacing:.06em}
.flight-row .fare{text-align:right}
.flight-row .fare .price{font-size:22px;font-weight:700;color:var(--navy-1);letter-spacing:-.01em}
.flight-row .fare .per{font-size:11px;color:var(--g500)}
.flight-row .pick{background:var(--navy-1);color:#fff;border:none;height:42px;padding:0 22px;border-radius:999px;font-weight:600;font-size:13px;cursor:pointer;transition:background .15s}
.flight-row .pick:hover{background:var(--navy-hover)}

/* Recent searches chips */
.recent-list{display:flex;gap:10px;flex-wrap:wrap}
.recent-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border:1px solid var(--border);border-radius:999px;background:#fff;cursor:pointer;transition:all .15s;font-size:13px;color:var(--navy-2)}
.recent-chip:hover{border-color:var(--navy-1);color:var(--navy-1)}
.recent-chip .arrow-x{color:var(--g400)}
.recent-chip strong{font-weight:600}

/* ---- SKYHEX about page ---- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:48px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stat{padding:32px 24px;border-right:1px solid var(--border);text-align:left}
.stat:last-child{border-right:none}
.stat .num{font-size:48px;font-weight:700;color:var(--navy-3);letter-spacing:-.03em;line-height:1}
.stat .lbl{font-size:13px;color:var(--g500);margin-top:8px;letter-spacing:.02em}
.story{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.story h2{font-size:32px;font-weight:700;color:var(--navy-3);letter-spacing:-.02em;margin:0;line-height:1.2}
.story p{font-size:15.5px;color:var(--g600);line-height:1.75;margin:0}

.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fleet-card{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden}
.fleet-card .img-ph{height:160px;border-radius:0}
.fleet-card .body{padding:18px 20px}
.fleet-card h4{margin:0 0 4px;font-size:17px;font-weight:700;color:var(--navy-3)}
.fleet-card .sub{font-size:13px;color:var(--g500)}
.fleet-card .specs{display:flex;gap:18px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.fleet-card .specs div{font-size:12px;color:var(--g500)}
.fleet-card .specs strong{display:block;color:var(--navy-2);font-size:15px;font-weight:700;margin-top:2px}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{padding:28px;background:#fff;border:1px solid var(--border);border-radius:18px}
.value .ico{width:44px;height:44px;border-radius:12px;background:var(--g50);color:var(--navy-1);display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px}
.value h4{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--navy-3);letter-spacing:-.005em}
.value p{margin:0;font-size:14px;color:var(--g600);line-height:1.6}

/* ---- Notices page ---- */
.np-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.np-filters{display:flex;gap:6px;flex-wrap:wrap}
.np-filter{height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--g600);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.np-filter:hover{border-color:var(--navy-1);color:var(--navy-1)}
.np-filter.active{background:var(--navy-1);color:#fff;border-color:var(--navy-1)}
.np-search{display:flex;align-items:center;gap:8px;height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:#fff;min-width:240px}
.np-search input{border:none;outline:none;flex:1;font-size:13px;font-family:inherit;background:transparent;color:var(--navy-2)}
.np-search input::placeholder{color:var(--g400)}
.np-search svg{color:var(--g500);flex-shrink:0}

.np-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}
.np-item{display:grid;grid-template-columns:120px 1fr auto;gap:20px;align-items:center;padding:22px 4px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.np-item:hover{background:var(--g50)}
.np-item .tag{display:inline-flex;align-items:center;justify-content:center;height:24px;padding:0 12px;font-size:11.5px;font-weight:600;letter-spacing:.04em;border-radius:999px;background:var(--g50);color:var(--navy-1);width:fit-content;text-transform:uppercase}
.np-item h4{margin:0;font-size:15.5px;font-weight:600;color:var(--navy-2);letter-spacing:-.005em}
.np-item .date{font-size:13px;color:var(--g500);white-space:nowrap}

/* ---- Contact page ---- */
.ch-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.channel{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px;transition:all .15s;cursor:pointer}
.channel:hover{border-color:var(--navy-1);box-shadow:var(--soft-shadow);transform:translateY(-2px)}
.channel .ico{width:48px;height:48px;border-radius:14px;background:var(--g50);color:var(--navy-1);display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px}
.channel h4{margin:0 0 6px;font-size:17px;font-weight:700;color:var(--navy-3)}
.channel p{margin:0 0 14px;font-size:13px;color:var(--g600);line-height:1.55}
.channel .more{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--navy-1)}

.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:#fff;border:1px solid var(--border);border-radius:24px;padding:32px}
.contact-form .full{grid-column:1 / -1}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--g600);letter-spacing:.03em;text-transform:uppercase}
.contact-form input,.contact-form select,.contact-form textarea{height:48px;border:1px solid var(--border);border-radius:12px;padding:0 14px;font-family:inherit;font-size:14.5px;color:var(--navy-2);background:#fff;outline:none;transition:border .15s,box-shadow .15s}
.contact-form textarea{height:auto;min-height:140px;padding:12px 14px;resize:vertical}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--navy-1);box-shadow:0 0 0 3px rgba(49,64,102,.1)}
.contact-form button{justify-self:end;display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 24px;background:var(--navy-1);color:#fff;border:none;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}
.contact-form button:hover{background:var(--navy-hover)}

/* ============== Pickers (airport/date/pax/cabin/seat) ============== */
.picker .modal{max-width:520px;padding:0;overflow:hidden}
.picker.wide .modal{max-width:680px}
.picker .ph{padding:24px 28px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border)}
.picker .ph h3{margin:0 0 4px;font-size:18px;font-weight:700;color:var(--navy-3);letter-spacing:-.01em}
.picker .ph p{margin:0;font-size:13px;color:var(--g500)}
.picker .pbody{padding:18px 28px 24px;max-height:60vh;overflow:auto}
.picker .search-row{padding:14px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.picker .search-row svg{color:var(--g500);flex-shrink:0}
.picker .search-row input{flex:1;border:none;outline:none;font-family:inherit;font-size:15px;color:var(--navy-2);background:transparent}
.picker .search-row input::placeholder{color:var(--g400)}

.airport-section{font-size:11px;font-weight:600;color:var(--g500);letter-spacing:.08em;text-transform:uppercase;padding:14px 0 8px}
.airport-row{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .12s}
.airport-row:hover{background:var(--g50)}
.airport-row.selected{background:#f3f6fb}
.airport-row .code{width:54px;flex-shrink:0;font-size:15px;font-weight:700;color:var(--navy-1);letter-spacing:.04em}
.airport-row .info{flex:1;min-width:0}
.airport-row .info .city{font-size:14.5px;font-weight:600;color:var(--navy-2)}
.airport-row .info .name{font-size:12.5px;color:var(--g500);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.airport-row .country{font-size:11.5px;color:var(--g500);background:var(--g50);padding:3px 8px;border-radius:6px;letter-spacing:.04em;font-weight:600}

/* Counter rows */
.count-row{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;border-bottom:1px solid var(--border)}
.count-row:last-of-type{border-bottom:none}
.count-row .lbl{display:flex;flex-direction:column}
.count-row .lbl .t{font-size:15px;font-weight:600;color:var(--navy-2)}
.count-row .lbl .s{font-size:12.5px;color:var(--g500);margin-top:2px}
.count-ctrl{display:flex;align-items:center;gap:14px}
.count-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:#fff;color:var(--navy-2);font-size:16px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s}
.count-btn:hover:not(:disabled){border-color:var(--navy-1);color:var(--navy-1)}
.count-btn:disabled{opacity:.35;cursor:not-allowed}
.count-val{font-size:18px;font-weight:700;color:var(--navy-3);min-width:24px;text-align:center}

/* Option rows */
.opt-row{display:flex;align-items:center;gap:14px;padding:14px 12px;border-radius:12px;border:1.5px solid var(--border);margin-bottom:8px;cursor:pointer;transition:all .12s;background:#fff;width:100%;text-align:left}
.opt-row:hover{border-color:var(--navy-1);background:var(--g50)}
.opt-row.selected{border-color:var(--navy-1);background:#f3f6fb}
.opt-row .ico{width:40px;height:40px;border-radius:10px;background:var(--g50);color:var(--navy-1);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.opt-row .info{flex:1}
.opt-row .info .t{font-size:15px;font-weight:600;color:var(--navy-2)}
.opt-row .info .s{font-size:12.5px;color:var(--g500);margin-top:2px}
.opt-row .check{color:var(--navy-1);opacity:0}
.opt-row.selected .check{opacity:1}

/* Calendar */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal .h{text-align:center;font-size:11px;font-weight:600;color:var(--g500);padding:8px 0;letter-spacing:.04em;text-transform:uppercase}
.cal .d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:14px;color:var(--navy-2);cursor:pointer;transition:all .1s;border:none;background:transparent;font-family:inherit;font-weight:500}
.cal .d:hover:not(:disabled):not(.empty){background:var(--g50);color:var(--navy-1)}
.cal .d.selected{background:var(--navy-1);color:#fff;font-weight:600}
.cal .d.today{font-weight:700;color:var(--navy-1)}
.cal .d.selected.today{color:#fff}
.cal .d:disabled{color:var(--g300);cursor:not-allowed}
.cal .d.empty{visibility:hidden;cursor:default}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-nav .month{font-size:16px;font-weight:700;color:var(--navy-3)}
.cal-nav button{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--navy-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s}
.cal-nav button:hover{border-color:var(--navy-1);color:var(--navy-1)}
.cal-nav button:disabled{opacity:.35;cursor:not-allowed}

/* Picker footer (apply button) */
.picker .pf{display:flex;justify-content:flex-end;gap:10px;padding:16px 28px;border-top:1px solid var(--border);background:var(--g50)}
.picker .pf .apply{height:42px;padding:0 24px;background:var(--navy-1);color:#fff;border:none;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}
.picker .pf .apply:hover{background:var(--navy-hover)}
.picker .pf .ghost{height:42px;padding:0 18px;background:transparent;color:var(--g600);border:none;border-radius:999px;font-size:14px;font-weight:500;cursor:pointer}
.picker .pf .ghost:hover{color:var(--navy-1)}

/* ============== Seat map ============== */
.seat .modal{max-width:820px}
/* Seat legend */
.seat .legend{display:flex;gap:14px;padding:10px 28px;border-bottom:1px solid var(--border);font-size:11.5px;color:var(--g500);flex-wrap:wrap}
.seat .legend .item{display:inline-flex;align-items:center;gap:5px}
.seat .legend .sw{width:16px;height:16px;border-radius:4px;background:#fff;border:1.5px solid var(--g300)}
.seat .legend .sw.first{background:#fef3c7;border-color:#d4a017}
.seat .legend .sw.business{background:#f3eddb;border-color:#c9b283}
.seat .legend .sw.premium{background:#ede9fe;border-color:#a78bfa}
.seat .legend .sw.taken{background:var(--g200);border-color:var(--g300)}
.seat .legend .sw.selected{background:var(--navy-1);border-color:var(--navy-1)}
/* Seat cells */
.cabin-section{padding:14px 28px;border-bottom:1px solid var(--border)}
.cabin-section:last-child{border-bottom:none}
.cabin-section h4{margin:0 0 12px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--g500)}
.seat-row{display:flex;align-items:center;gap:5px;margin-bottom:5px;justify-content:center}
.seat-row .row-num{width:24px;font-size:11px;color:var(--g500);text-align:center;font-weight:600}
.seat-cell{width:28px;height:28px;border-radius:5px;border:1.5px solid var(--g300);background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:9.5px;color:var(--g500);cursor:pointer;font-weight:600;transition:all .1s;font-family:inherit}
.seat-cell:hover:not(.taken):not(.empty){border-color:var(--navy-1);color:var(--navy-1);transform:scale(1.08)}
.seat-cell.taken{background:var(--g200);border-color:var(--g200);cursor:not-allowed;color:var(--g400)}
.seat-cell.selected{background:var(--navy-1) !important;border-color:var(--navy-1) !important;color:#fff !important}
/* First class — gold */
.seat-cell.first{background:#fef9e7;border-color:#e8c84a;width:34px;height:34px;font-size:10px;border-radius:7px}
.seat-cell.first.taken{background:#f5e6a3;border-color:#c9a820}
/* Business — warm ivory */
.seat-cell.business{background:#f9f4e3;border-color:#d4be86;width:32px;height:32px;border-radius:6px}
.seat-cell.business.taken{background:#ede4c5;border-color:#c2aa72}
/* Premium — soft purple */
.seat-cell.premium{background:#f5f3ff;border-color:#c4b5fd}
.seat-cell.premium.taken{background:#ddd6fe;border-color:#a78bfa}
.seat-cell.empty{visibility:hidden;cursor:default}
.aisle{width:22px;display:inline-block;flex-shrink:0}
/* Seat unavailable prompt */
.seat-no-ac{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:10px;color:var(--g400)}
.seat-no-ac svg{opacity:.4}
.seat-no-ac p{margin:0;font-size:14px}
/* Summary */
.seat .summary{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:var(--g50);border-top:1px solid var(--border)}
.seat .summary .info{font-size:13.5px;color:var(--navy-2)}
.seat .summary .info strong{display:block;font-size:16px;color:var(--navy-3);margin-top:2px}
.seat .summary .confirm{height:44px;padding:0 24px;background:var(--navy-1);color:#fff;border:none;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer}
.seat .summary .confirm:disabled{opacity:.5;cursor:not-allowed}

/* ============== Toast ============== */
.toast{position:fixed;left:50%;bottom:32px;transform:translateX(-50%) translateY(20px);background:var(--navy-3);color:#fff;padding:14px 22px;border-radius:999px;font-size:14px;z-index:1100;box-shadow:0 10px 40px rgba(7,21,54,.3);opacity:0;pointer-events:none;transition:all .25s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg{display:inline-block;vertical-align:-3px;margin-right:8px}
@media (max-width: 1080px){
  .hero h1{font-size:48px}
  .dest-grid{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(3){border-top:1px solid var(--border)}
  .stat:nth-child(4){border-top:1px solid var(--border)}
  .story{grid-template-columns:1fr;gap:20px}
  .fleet-grid{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .ch-grid{grid-template-columns:1fr 1fr}
  .flight-row{grid-template-columns:auto 1fr;gap:16px}
  .flight-row .fare,.flight-row .pick{grid-column:2}
  .flight-row .pick{justify-self:end}
  .b-form{grid-template-columns:1fr 1fr;grid-auto-rows:auto}
  .b-form .field{border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
  .b-form .field:nth-child(even){border-right:none}
  .b-form .search-btn{grid-column:1 / -1;min-height:60px}
  .grid-two{grid-template-columns:1fr}
  .nl-grid{grid-template-columns:1fr 1fr}
  .nl-item:nth-child(3){border-top:1px solid var(--border);padding-top:20px}
  footer .grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  .container{padding:0 20px}
  .dest-grid{grid-template-columns:1fr}
  .fleet-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .ch-grid{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat{padding:24px 16px}
  .stat .num{font-size:36px}
  .contact-form{grid-template-columns:1fr;padding:24px}
  .np-item{grid-template-columns:1fr;gap:6px}
  .np-item .date{justify-self:start}
  .flight-row{grid-template-columns:1fr;gap:14px;padding:18px}
  .flight-row .timeline{justify-content:space-between}
  .flight-row .point .time{font-size:18px}
  .flight-row .fare,.flight-row .pick{grid-column:1;justify-self:start;text-align:left}
  .utilbar .left a:nth-child(n+3){display:none}
  nav.main-nav{display:none}
  .hamburger{display:inline-flex}
  .hero .container{padding-top:48px;padding-bottom:88px}
  .hero h1{font-size:36px}
  .hero .sub{font-size:15px}
  .page-hero h1{font-size:30px}
  .b-tabs{overflow-x:auto;scrollbar-width:none}
  .b-tabs::-webkit-scrollbar{display:none}
  .b-tab{flex:0 0 auto;padding:0 22px;height:56px;font-size:14px}
  .b-body{padding:20px}
  .b-form{grid-template-columns:1fr}
  .b-form .field{border-right:none}
  .b-form .search-btn{min-height:56px}
  .field.from .swap{right:14px;top:auto;bottom:-22px;transform:none}
  .field.from .swap:hover{transform:rotate(90deg)}
  .shortcut-grid{grid-template-columns:repeat(3,1fr)}
  .nl-grid{grid-template-columns:1fr}
  .nl-item:nth-child(2),.nl-item:nth-child(3){border-top:1px solid var(--border);padding-top:20px}
  footer .grid{grid-template-columns:1fr}
  .promo{padding:28px;min-height:auto}
  .promo h2{font-size:28px}
  .shortcuts,.notice-list-card{padding:24px}
  .sec-head .title{font-size:18px}
  .h-only-mobile{display:initial}
}



/* ===== Value grid (about.html) ===== */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.value-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:28px 24px}
.value-card .ico{width:52px;height:52px;border-radius:14px;background:var(--g50);color:var(--navy-1);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.value-card h4{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--navy-3)}
.value-card p{margin:0;font-size:14px;color:var(--g600);line-height:1.6}
@media(max-width:720px){.value-grid{grid-template-columns:1fr}}

/* ===== Destination card override for travel.js inline style ===== */
a.dest-card{text-decoration:none;padding:24px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:16px}
.dest-card .dest-info .codes{font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--navy-1);text-transform:uppercase;margin-bottom:6px}
.dest-card .dest-info h4{margin:0 0 2px;font-size:20px;font-weight:700;color:var(--navy-3)}
.dest-card .dest-info .country{font-size:13px;color:var(--g500)}
.dest-card .dest-meta{text-align:right;flex-shrink:0}
.dest-card .dest-meta .price{font-size:18px;font-weight:700;color:var(--navy-1)}
.dest-card .dest-meta .dur{font-size:12px;color:var(--g500);margin-top:2px}
.dest-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:720px){.dest-grid{grid-template-columns:1fr}}

/* ===== Extended component styles ===== */
.lang-option .flag { background: #f1f3f7; }
.lang-option .flag svg { border-radius: 50%; }

nav.main-nav a.active { background: #eef2f7; color: var(--navy-1); }
nav.main-nav a.active::after { display: none !important; }

footer .designer-credit {
  font-size: 11.5px;
  color: rgba(255,255,255,.4);
  margin-top: 14px;
  letter-spacing: .04em;
  font-weight: 500;
}

.rm-card { background:#fff; border:1px solid var(--border); border-radius:18px; padding:24px 28px; transition:all .15s }
.rm-card:hover { border-color: var(--navy-1); box-shadow: var(--soft-shadow); }
.rm-route-header { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:8px }
.rm-route-header .codes { font-size:24px; font-weight:700; color:var(--navy-3); letter-spacing:-.01em; display:flex; align-items:center; gap:10px }
.rm-route-header .codes .arrow-ico { color: var(--g400); }
.rm-route-header .badge { font-size:10.5px; font-weight:700; letter-spacing:.06em; padding:3px 10px; border-radius:999px; background:var(--g50); color:var(--navy-1); text-transform:uppercase }
.rm-meta { display:flex; gap:28px; flex-wrap:wrap; padding-top:14px; border-top:1px solid var(--border); margin-top:12px }
.rm-meta div { font-size:12px; color:var(--g500); }
.rm-meta strong { display:block; color:var(--navy-2); font-size:14.5px; font-weight:600; margin-top:3px }
.rm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width:720px){ .rm-grid{grid-template-columns:1fr} }

.ti-card { display:flex; gap:18px; padding:22px 24px; border:1px solid var(--border); border-radius:18px; background:#fff; transition:all .15s; cursor:pointer }
.ti-card:hover { border-color: var(--navy-1); box-shadow: var(--soft-shadow); }
.ti-card .ti-ico { width:48px; height:48px; border-radius:12px; background:var(--g50); color:var(--navy-1); display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.ti-card .ti-cat { font-size:11px; font-weight:600; letter-spacing:.08em; color:var(--g500); text-transform:uppercase; margin-bottom:4px }
.ti-card .ti-title { font-size:16px; font-weight:600; color:var(--navy-3); margin:0 0 6px }
.ti-card .ti-sum { font-size:13.5px; color:var(--g600); line-height:1.55; margin:0 }
.ti-list { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width:720px){ .ti-list{grid-template-columns:1fr} }

.bg-table { width:100%; border-collapse: collapse; background:#fff; border:1px solid var(--border); border-radius:16px; overflow:hidden }
.bg-table th { text-align:left; font-size:12px; font-weight:600; color:var(--g500); letter-spacing:.06em; text-transform:uppercase; padding:14px 18px; background: var(--g50); border-bottom:1px solid var(--border) }
.bg-table td { padding:18px; font-size:14px; color:var(--navy-2); border-bottom:1px solid var(--border) }
.bg-table tr:last-child td { border-bottom: none; }
.bg-table td strong { color: var(--navy-3); font-weight:600 }
.bg-note { padding:14px 18px; background:var(--g50); border-radius:12px; font-size:13px; color:var(--g600); margin-top:18px; line-height:1.6 }

.tab-panel { display: none; }
.tab-panel.active { display: block; animation: fadein .25s ease-out; }
@keyframes fadein { from { opacity:0; transform:translateY(4px) } to { opacity:1; transform:none } }

.trips-panel { padding: 8px 4px 4px }
.trips-panel h4 { margin: 0 0 6px; font-size: 17px; font-weight: 700; color: var(--navy-3); letter-spacing: -.01em }
.trips-panel p { margin: 0 0 18px; font-size: 14px; color: var(--g600) }
.trips-form { display: flex; gap: 12px; max-width: 560px }
.trips-form input { flex: 1; height: 52px; border: 1.5px solid var(--border); border-radius: 14px; padding: 0 18px; font-family: inherit; font-size: 15px; font-weight: 600; letter-spacing: .12em; color: var(--navy-2); background: #fff; outline: none; text-transform: uppercase; transition: border .15s, box-shadow .15s }
.trips-form input:focus { border-color: var(--navy-1); box-shadow: 0 0 0 3px rgba(49,64,102,.1) }
.trips-form button { display: inline-flex; align-items: center; gap: 8px; padding: 0 26px; height: 52px; background: var(--navy-1); color: #fff; border: none; border-radius: 14px; font-size: 14px; font-weight: 600; cursor: pointer; transition: background .15s }
.trips-form button:hover { background: var(--navy-hover) }
.trips-result { margin-top: 22px; padding: 22px; border: 1px solid var(--border); border-radius: 14px; background: var(--g50); font-size: 14px; color: var(--navy-2); display: none }
.trips-result.show { display: block; animation: fadein .2s ease-out }
.trips-result.error { background: #fff5f5; border-color: #ffd9d9; color: #9a3030 }
.trips-result.ok { background: #f0f6ff; border-color: #d6e3f4 }
.trips-hint { margin-top: 14px; font-size: 12px; color: var(--g500); display: flex; align-items: center; gap: 6px }
.trips-hint code { background: var(--g50); padding: 3px 8px; border-radius: 5px; color: var(--navy-1); font-weight: 600; letter-spacing: .08em; font-family: ui-monospace, monospace; font-size: 11px }

.checkin-panel { padding: 30px 8px 12px; text-align: center }
.checkin-icon { width: 64px; height: 64px; border-radius: 50%; background: var(--g50); color: var(--navy-1); display: inline-flex; align-items: center; justify-content: center; margin: 0 auto 18px }
.checkin-icon svg { animation: spin 1.6s linear infinite }
@keyframes spin { to { transform: rotate(360deg) } }
.checkin-panel h4 { margin: 0 0 8px; font-size: 20px; font-weight: 700; color: var(--navy-3); letter-spacing: -.01em }
.checkin-panel p { margin: 0 0 12px; font-size: 14px; color: var(--g600) }
.checkin-panel .count { font-size: 13px; color: var(--g500); font-weight: 500 }
.checkin-panel .count strong { color: var(--navy-1); font-weight: 700 }

.cs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; padding: 4px }
@media (max-width: 720px){ .cs-grid { grid-template-columns: 1fr } }
.cs-card { display: flex; align-items: center; gap: 16px; padding: 22px; border: 1px solid var(--border); border-radius: 16px; background: #fff; cursor: pointer; transition: all .15s; text-decoration: none; color: inherit }
.cs-card:hover { transform: translateY(-2px); box-shadow: var(--soft-shadow); border-color: var(--navy-1) }
.cs-card .cs-logo { width: 56px; height: 56px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0 }
.cs-card.discord .cs-logo { background: linear-gradient(135deg, #5865F2, #4752c4); color: #fff }
.cs-card.channel .cs-logo { background: linear-gradient(135deg, #FFCE00, #ffb300); color: #1a1a1a }
.cs-card .cs-body { flex: 1; min-width: 0 }
.cs-card h4 { margin: 0 0 4px; font-size: 16px; font-weight: 700; color: var(--navy-3); letter-spacing: -.005em }
.cs-card .cs-sub { font-size: 13px; color: var(--g500); line-height: 1.45 }
.cs-card .cs-go { color: var(--navy-1); display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600; margin-top: 8px }

.fs-row { display: grid; grid-template-columns: 1fr 2fr 1fr; gap: 22px; align-items: center; padding: 22px 24px; border: 1px solid var(--border); border-radius: 16px; background: #fff; transition: all .15s }
.fs-row + .fs-row { margin-top: 12px }
.fs-row:hover { border-color: var(--navy-1) }
.fs-row .fs-num { font-size: 15px; font-weight: 700; color: var(--navy-3); letter-spacing: .04em }
.fs-row .fs-route { font-size: 12.5px; color: var(--g500); margin-top: 3px }
.fs-row .fs-line { display: flex; align-items: center; gap: 14px }
.fs-row .fs-time { font-size: 18px; font-weight: 700; color: var(--navy-2); min-width: 56px; text-align: center }
.fs-row .fs-bar { flex: 1; height: 1px; background: var(--g300); position: relative }
.fs-row .fs-bar::before, .fs-row .fs-bar::after { content: ""; position: absolute; top: -2px; width: 5px; height: 5px; border-radius: 50%; background: var(--navy-1) }
.fs-row .fs-bar::before { left: 0 } .fs-row .fs-bar::after { right: 0 }
.fs-row .fs-stat { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; font-size: 11.5px; font-weight: 700; letter-spacing: .04em; justify-self: end; text-transform: uppercase }
.fs-row .fs-stat.ontime { background: #e8f6ec; color: #1e7c3a }
.fs-row .fs-stat.delayed { background: #fff5e0; color: #a66200 }
.fs-row .fs-stat.boarding { background: #e7f0ff; color: #2453b3 }
.fs-row .fs-stat .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor }
@media (max-width: 720px) { .fs-row { grid-template-columns: 1fr; gap: 10px } .fs-row .fs-stat { justify-self: start } }

.utilbar .left, .utilbar .right { align-items: stretch; }
.utilbar a, .utilbar button {
  display: inline-flex !important;
  align-items: center !important;
  height: 36px !important;
  line-height: 1 !important;
  margin: 0 !important;
  vertical-align: middle;
  box-sizing: border-box;
  padding: 0 14px;
}
.utilbar svg { display: block; flex-shrink: 0; }
.utilbar .lang-btn .caret { width: 10px; height: 10px; }

/* Auth state */
.util-user { display: inline-flex; align-items: center; gap: 8px; height: 36px; padding: 0 14px; font-size: 13px; color: var(--navy-2); font-weight: 500; }
.util-user img { width: 22px; height: 22px; border-radius: 50%; }
.hidden { display: none !important; }

/* mypage-btn as anchor */
a.mypage-btn { display:inline-flex;align-items:center;gap:6px;padding:0 14px;height:40px;border-radius:10px;color:var(--navy-2);font-size:14px;font-weight:500;text-decoration:none;border:1px solid var(--border);transition:all .15s }
a.mypage-btn:hover { background:var(--g50);border-color:var(--navy-1) }
/* drawer primary as anchor */
.drawer-foot a.primary { height:44px;border-radius:10px;background:var(--navy-1);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none }

/* ── Mobile UI improvements ── */
@media (max-width: 720px) {
  /* Utilbar: hide all left links, only keep lang button */
  .utilbar .left a { display:none !important }
  .utilbar .left .lang-btn { display:inline-flex !important }
  /* Util right: compact */
  .utilbar .right { gap:2px }
  #util-login { font-size:12px;padding:0 10px }
  .utilbar .sep { display:none }
  /* Header: tighter padding */
  .header .container { padding:0 16px;height:56px }
  .brand img { height:26px }
  /* Booking tabs: better scroll indicator */
  .b-tabs { gap:0;border-bottom:2px solid var(--border) }
  .b-tab { min-width:90px;font-size:13px;gap:5px }
  .b-tab svg { width:16px;height:16px }
  /* Booking body */
  .b-form .field { padding:14px 16px }
  .b-form .field .label { font-size:11px;margin-bottom:4px }
  .b-form .field .val .code { font-size:22px }
  /* Shortcut grid: 4 cols on mobile */
  .shortcut-grid { grid-template-columns:repeat(4,1fr);gap:10px }
  .shortcut-item { padding:14px 10px;gap:8px }
  .shortcut-item .ico { width:36px;height:36px }
  .shortcut-item .lbl { font-size:11px }
  /* Section headings */
  .sec-head { margin-bottom:16px }
  /* Footer: single column, compact */
  footer { padding:32px 0 24px }
  footer .grid { gap:24px }
  footer .grid > div { padding-bottom:0 }
  footer .grid h5 { font-size:13px;margin-bottom:8px }
  footer .grid ul li a { font-size:13px }
  footer .bottom { flex-direction:column;gap:12px;align-items:flex-start;padding-top:20px }
  /* Drawer: full-width on very small screens */
  .drawer { width:100%;max-width:340px }
  .drawer-nav a { font-size:15px;padding:13px 16px }
  /* Page hero */
  .page-hero { padding:40px 0 36px }
  .page-hero h1 { font-size:26px }
  /* Notices page toolbar */
  .np-toolbar { flex-direction:column;gap:10px }
  .np-filters { flex-wrap:wrap;gap:6px }
  .np-search { width:100% }
  /* My trips panel */
  .trips-panel { padding:24px 20px }
  /* Contact form */
  .contact-form input,.contact-form select,.contact-form textarea { font-size:16px }
}
