/* Café de Gill — Frankfurt. Prefix: cg- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;1,9..144,400&family=Inter:wght@400;500;600&display=swap');

:root{
  --cg-cream:#f7f1e6;
  --cg-paper:#fffdf8;
  --cg-espresso:#3b2419;
  --cg-coffee:#6f4a33;
  --cg-caramel:#c08a52;
  --cg-sage:#8a9a7b;
  --cg-ink:#2c211a;
  --cg-gray:#8a7d70;
  --cg-line:#e4d8c5;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--cg-ink);background:var(--cg-cream);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:'Fraunces',serif;font-weight:600;line-height:1.12;color:var(--cg-espresso)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.cg-container{width:90%;max-width:1140px;margin:0 auto}

/* NAV */
.cg-nav{position:sticky;top:0;z-index:50;background:rgba(247,241,230,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--cg-line)}
.cg-nav .cg-container{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.cg-brand{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:600;letter-spacing:.3px;color:var(--cg-espresso)}
.cg-brand span{color:var(--cg-caramel)}
.cg-links{display:flex;gap:30px;list-style:none}
.cg-links a{font-size:.93rem;font-weight:500;color:var(--cg-coffee);transition:color .2s}
.cg-links a:hover,.cg-links a.on{color:var(--cg-caramel)}
.cg-tog{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px}
.cg-tog span{width:24px;height:2px;background:var(--cg-espresso);border-radius:2px}

/* BUTTONS */
.cg-btn{display:inline-block;background:var(--cg-espresso);color:var(--cg-cream);padding:13px 30px;border-radius:999px;font-weight:600;font-size:.92rem;border:0;cursor:pointer;transition:transform .2s,background .2s}
.cg-btn:hover{background:var(--cg-coffee);transform:translateY(-2px)}
.cg-btn.ghost{background:transparent;color:var(--cg-espresso);border:1.5px solid var(--cg-espresso);margin-left:10px}
.cg-btn.ghost:hover{background:var(--cg-espresso);color:var(--cg-cream)}

/* HERO */
.cg-hero{position:relative;overflow:hidden}
.cg-hero img{width:100%;height:78vh;min-height:480px;object-fit:cover;filter:brightness(.62) saturate(1.05)}
.cg-hero-inner{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.cg-hero-inner .cg-container{color:var(--cg-cream)}
.cg-kick{display:inline-block;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;color:var(--cg-caramel);margin-bottom:18px}
.cg-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:#fff;max-width:14ch;font-weight:400}
.cg-hero h1 em{font-style:italic;color:var(--cg-caramel)}
.cg-hero p{color:#f0e7d8;max-width:46ch;margin:20px 0 30px;font-size:1.05rem}

/* SECTIONS */
.cg-sec{padding:88px 0}
.cg-sec.paper{background:var(--cg-paper)}
.cg-shead{max-width:640px;margin-bottom:48px}
.cg-shead.center{margin-left:auto;margin-right:auto;text-align:center}
.cg-shead h2{font-size:clamp(2rem,4vw,2.9rem);font-weight:400;margin:8px 0 14px}
.cg-shead p{color:var(--cg-gray);font-size:1.05rem}

/* SPLIT */
.cg-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.cg-split img{border-radius:18px;box-shadow:0 24px 50px rgba(59,36,25,.16)}
.cg-split h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:400;margin-bottom:16px}
.cg-split p{color:var(--cg-coffee);margin-bottom:14px}
.cg-check{list-style:none;margin-top:18px}
.cg-check li{position:relative;padding-left:30px;margin-bottom:12px;color:var(--cg-ink)}
.cg-check li::before{content:'☕';position:absolute;left:0;top:0}

/* MENU CARDS */
.cg-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cg-card{background:var(--cg-paper);border:1px solid var(--cg-line);border-radius:16px;padding:32px 28px;transition:transform .25s,box-shadow .25s}
.cg-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(59,36,25,.12)}
.cg-card .cg-ico{font-size:2rem;margin-bottom:14px}
.cg-card h3{font-size:1.3rem;font-weight:600;margin-bottom:10px}
.cg-card p{color:var(--cg-gray);font-size:.95rem}

/* PRICE LIST */
.cg-list{max-width:680px;margin:0 auto;display:grid;gap:6px}
.cg-row{display:flex;align-items:baseline;gap:14px;padding:14px 0;border-bottom:1px dashed var(--cg-line)}
.cg-row .name{font-family:'Fraunces',serif;font-size:1.15rem;color:var(--cg-espresso)}
.cg-row .dots{flex:1;border-bottom:2px dotted var(--cg-line);transform:translateY(-4px)}
.cg-row .price{font-weight:600;color:var(--cg-caramel)}
.cg-row small{display:block;color:var(--cg-gray);font-size:.85rem;font-family:'Inter',sans-serif}

/* BAND */
.cg-band{background:var(--cg-espresso);color:var(--cg-cream);padding:64px 0}
.cg-band .cg-container{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.cg-band b{display:block;font-family:'Fraunces',serif;font-size:2.6rem;color:var(--cg-caramel);font-weight:600}
.cg-band span{font-size:.9rem;color:#d9cdbb}

/* QUOTE */
.cg-quote{text-align:center;max-width:760px;margin:0 auto}
.cg-quote p{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.4rem,3vw,2rem);color:var(--cg-espresso);line-height:1.4}
.cg-quote cite{display:block;margin-top:20px;font-style:normal;color:var(--cg-gray);font-size:.95rem}

/* CONTACT */
.cg-cgrid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px}
.cg-cbox{margin-bottom:24px}
.cg-cbox h4{font-size:1.1rem;margin-bottom:6px}
.cg-cbox p{color:var(--cg-coffee)}
.cg-cbox a{color:var(--cg-caramel)}
.cg-form label{display:block;font-size:.85rem;font-weight:600;margin:14px 0 6px;color:var(--cg-coffee)}
.cg-form input,.cg-form textarea{width:100%;padding:13px 16px;border:1px solid var(--cg-line);border-radius:12px;background:var(--cg-paper);font-family:inherit;font-size:.95rem;color:var(--cg-ink)}
.cg-form input:focus,.cg-form textarea:focus{outline:none;border-color:var(--cg-caramel)}
.cg-form textarea{min-height:120px;resize:vertical}
.cg-map{margin-top:46px;border-radius:18px;overflow:hidden;border:1px solid var(--cg-line)}
.cg-map iframe{width:100%;height:360px;border:0;display:block}

/* LEGAL */
.cg-legal{max-width:760px}
.cg-legal h1{font-size:2.4rem;font-weight:400;margin-bottom:8px}
.cg-legal .upd{color:var(--cg-gray);margin-bottom:30px}
.cg-legal h2{font-size:1.3rem;font-weight:600;margin:28px 0 10px}
.cg-legal p,.cg-legal li{color:var(--cg-coffee);margin-bottom:10px}
.cg-legal ul{padding-left:22px;margin-bottom:10px}

/* FOOTER */
.cg-footer{background:#2a1a12;color:#cdbca9;padding:60px 0 28px}
.cg-fgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:34px}
.cg-footer .cg-brand{color:#fff;display:block;margin-bottom:14px}
.cg-footer h5{color:#fff;font-family:'Fraunces',serif;margin-bottom:14px;font-size:1.05rem}
.cg-footer a{display:block;color:#cdbca9;margin-bottom:8px;font-size:.92rem}
.cg-footer a:hover{color:var(--cg-caramel)}
.cg-fbot{border-top:1px solid #43342a;padding-top:22px;font-size:.85rem;color:#9d8c79}

/* COOKIE */
.cg-cookie{position:fixed;left:20px;right:20px;bottom:20px;max-width:560px;margin:0 auto;background:var(--cg-paper);border:1px solid var(--cg-line);border-radius:18px;box-shadow:0 24px 60px rgba(59,36,25,.22);padding:24px;z-index:100}
.cg-cookie.hide{display:none}
.cg-cookie h4{font-size:1.15rem;margin-bottom:8px}
.cg-cookie p{font-size:.9rem;color:var(--cg-gray);margin-bottom:14px}
.cg-ck-opts{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;font-size:.88rem}
.cg-ck-opts label{display:flex;align-items:center;gap:7px;color:var(--cg-coffee)}
.cg-ck-btns{display:flex;flex-wrap:wrap;gap:10px}
.cg-ck-btns button{flex:1;min-width:120px;padding:11px;border-radius:999px;border:1px solid var(--cg-espresso);background:transparent;color:var(--cg-espresso);font-weight:600;font-size:.85rem;cursor:pointer;font-family:inherit}
.cg-ck-btns .cg-ck-all{background:var(--cg-espresso);color:var(--cg-cream)}

@media(max-width:820px){
  .cg-links{position:absolute;top:64px;left:0;right:0;background:var(--cg-cream);flex-direction:column;gap:0;padding:0 5%;max-height:0;overflow:hidden;transition:max-height .3s;border-bottom:1px solid var(--cg-line)}
  .cg-links.open{max-height:320px;padding:14px 5%}
  .cg-links a{padding:12px 0;border-bottom:1px solid var(--cg-line)}
  .cg-tog{display:flex}
  .cg-split,.cg-cgrid{grid-template-columns:1fr;gap:34px}
  .cg-menu{grid-template-columns:1fr}
  .cg-band .cg-container{grid-template-columns:repeat(2,1fr);gap:24px}
  .cg-fgrid{grid-template-columns:1fr}
}
