/* ===== IDE COUNSEL — Immigration Law (Italy, Milano) ===== */
/* Style: bright, optimistic, azure + coral, bento grid, timeline, rounded, energetic */

:root{
  --azure:#1763f5;
  --azure-d:#0d3fae;
  --coral:#ff6b5e;
  --coral-d:#e8523f;
  --mint:#10c4a0;
  --ink:#10172a;
  --slate:#5a6480;
  --bg:#ffffff;
  --bg-2:#f4f7fd;
  --bg-3:#eaf1fe;
  --line:#e2e8f4;
  --display:"Sora",-apple-system,system-ui,sans-serif;
  --body:"DM Sans",-apple-system,system-ui,sans-serif;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* Header */
.nav{position:fixed;top:18px;left:0;right:0;z-index:100}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.nav-bar{background:rgba(255,255,255,.85);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:50px;padding:12px 14px 12px 26px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 10px 40px -20px rgba(23,99,245,.3)}
.logo{font-family:var(--display);font-size:1.35rem;font-weight:700;color:var(--azure-d);letter-spacing:-.5px}
.logo span{color:var(--coral)}
.menu{display:flex;gap:30px;list-style:none}
.menu a{font-size:.9rem;font-weight:600;color:var(--ink);transition:.3s}
.menu a:hover,.menu a.active{color:var(--azure)}
.nav-cta{font-size:.86rem;font-weight:700;color:#fff;background:var(--azure);padding:11px 22px;border-radius:50px;transition:.3s}
.nav-cta:hover{background:var(--azure-d)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{width:24px;height:2px;background:var(--azure-d);border-radius:2px}

/* Hero */
.hero{padding:170px 0 90px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(23,99,245,.12),transparent 70%);border-radius:50%}
.hero::after{content:"";position:absolute;bottom:-150px;left:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(255,107,94,.1),transparent 70%);border-radius:50%}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:var(--azure);background:var(--bg-3);padding:8px 18px;border-radius:50px;margin-bottom:24px}
.hero-badge .dot{width:8px;height:8px;background:var(--mint);border-radius:50%}
.hero h1{font-family:var(--display);font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:700;line-height:1.05;letter-spacing:-1.5px;margin-bottom:24px}
.hero h1 span{color:var(--azure);position:relative}
.hero h1 span::after{content:"";position:absolute;left:0;bottom:6px;width:100%;height:10px;background:rgba(255,107,94,.3);z-index:-1}
.hero p{font-size:1.12rem;color:var(--slate);max-width:480px;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-visual .main-img{border-radius:28px;overflow:hidden;box-shadow:0 40px 80px -36px rgba(23,99,245,.5)}
.hero-visual .main-img img{width:100%;height:520px;object-fit:cover}
.hero-float{position:absolute;background:#fff;border-radius:18px;padding:18px 22px;box-shadow:0 24px 50px -24px rgba(16,23,42,.3);display:flex;align-items:center;gap:14px}
.hero-float.f1{top:30px;left:-30px}
.hero-float.f2{bottom:40px;right:-24px}
.hero-float .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.hero-float .ic.b{background:var(--bg-3)}.hero-float .ic.c{background:#ffe9e6}
.hero-float h5{font-size:1.1rem;font-weight:700}
.hero-float p{font-size:.78rem;color:var(--slate);margin:0}

.btn{display:inline-flex;align-items:center;gap:9px;font-size:.94rem;font-weight:700;padding:15px 30px;border-radius:50px;transition:.3s;cursor:pointer;border:none}
.btn-azure{background:var(--azure);color:#fff}
.btn-azure:hover{background:var(--azure-d);transform:translateY(-2px)}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{background:var(--coral-d);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--azure);color:var(--azure)}

.pad{padding:100px 0}
.eyebrow{font-size:.82rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--coral);margin-bottom:14px}
.sec-title{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-1px;line-height:1.1}
.sec-sub{color:var(--slate);max-width:560px;font-size:1.05rem}
.center{text-align:center}.center .sec-sub{margin-left:auto;margin-right:auto;margin-top:16px}

/* Logos strip */
.logos{background:var(--bg-2);padding:40px 0}
.logos .wrap{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:30px}
.logos span{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--slate);opacity:.6}

/* Bento services */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:22px;margin-top:56px}
.bcard{border-radius:24px;padding:32px;position:relative;overflow:hidden;transition:.4s;border:1px solid var(--line);background:#fff}
.bcard:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(16,23,42,.3)}
.bcard .ic{font-size:1.8rem;margin-bottom:14px}
.bcard h4{font-family:var(--display);font-size:1.25rem;font-weight:700;margin-bottom:8px}
.bcard p{font-size:.9rem;color:var(--slate)}
.bcard.big{grid-column:span 2;grid-row:span 2;background:linear-gradient(140deg,var(--azure),var(--azure-d));color:#fff}
.bcard.big h4{font-size:1.8rem}.bcard.big p{color:rgba(255,255,255,.85);font-size:1rem}
.bcard.coral{background:linear-gradient(140deg,var(--coral),var(--coral-d));color:#fff;grid-column:span 2}
.bcard.coral p{color:rgba(255,255,255,.9)}
.bcard.wide{grid-column:span 2}

/* Timeline */
.timeline{background:var(--bg-2)}
.tl{position:relative;max-width:760px;margin:56px auto 0;padding-left:40px}
.tl::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:42px}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--azure)}
.tl-item:last-child{padding-bottom:0}
.tl-item h4{font-family:var(--display);font-size:1.3rem;font-weight:700;margin-bottom:6px}
.tl-item .step{font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--coral);margin-bottom:6px}
.tl-item p{color:var(--slate);font-size:.95rem}

/* Split feature diagonal */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.feature-img{border-radius:24px;overflow:hidden;box-shadow:0 30px 70px -40px rgba(23,99,245,.4)}
.feature-img img{width:100%;height:460px;object-fit:cover}
.feature-txt ul{list-style:none;margin-top:24px}
.feature-txt li{display:flex;gap:12px;padding:12px 0;font-size:.98rem}
.feature-txt li .chk{width:24px;height:24px;border-radius:50%;background:var(--bg-3);color:var(--azure);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:.85rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{background:var(--bg-2);border-radius:24px;padding:40px 28px;text-align:center}
.stat h3{font-family:var(--display);font-size:2.8rem;font-weight:800;color:var(--azure)}
.stat p{color:var(--slate);font-size:.9rem;margin-top:4px}

/* Testimonial cards */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:24px;padding:36px}
.tcard .stars{color:var(--coral);margin-bottom:14px}
.tcard p{font-size:.98rem;margin-bottom:20px}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .av{width:44px;height:44px;border-radius:50%;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--azure)}
.tcard .who h5{font-size:.95rem;font-weight:700}
.tcard .who span{font-size:.8rem;color:var(--slate)}

/* CTA */
.cta{border-radius:32px;background:linear-gradient(135deg,var(--azure),var(--azure-d));color:#fff;padding:80px 60px;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;top:-80px;right:-80px;width:300px;height:300px;background:rgba(255,107,94,.25);border-radius:50%}
.cta .sec-title{color:#fff;position:relative}
.cta p{color:rgba(255,255,255,.9);max-width:520px;margin:16px auto 30px;position:relative}

/* Footer */
.footer{background:var(--ink);color:rgba(255,255,255,.6);padding:72px 0 36px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:44px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo{color:#fff;margin-bottom:14px}
.footer h5{color:#fff;font-size:.8rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px}
.footer ul{list-style:none}
.footer li{margin-bottom:11px;font-size:.9rem}
.footer a:hover{color:var(--coral)}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;font-size:.82rem;flex-wrap:wrap;gap:12px}

/* Page hero */
.phero{padding:170px 0 70px;text-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
.phero::before{content:"";position:absolute;top:-150px;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(23,99,245,.1),transparent 70%)}
.phero .crumb{font-size:.82rem;color:var(--slate);margin-bottom:16px;position:relative}
.phero .crumb a:hover{color:var(--azure)}
.phero h1{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;letter-spacing:-1px;margin-bottom:14px;position:relative}
.phero p{color:var(--slate);max-width:560px;margin:0 auto;position:relative}

/* Values */
.vals{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:24px;padding:40px 32px}
.vcard .ic{width:56px;height:56px;border-radius:16px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:20px}
.vcard h4{font-family:var(--display);font-size:1.3rem;font-weight:700;margin-bottom:10px}
.vcard p{color:var(--slate);font-size:.92rem}

/* Team */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.tm{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden}
.tm-img{height:300px;overflow:hidden}
.tm-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.tm:hover .tm-img img{transform:scale(1.05)}
.tm-info{padding:24px}
.tm-info h4{font-family:var(--display);font-size:1.25rem;font-weight:700}
.tm-info .role{color:var(--coral);font-size:.82rem;font-weight:700;margin:4px 0 10px}
.tm-info p{font-size:.88rem;color:var(--slate)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px}
.cinfo .cblk{background:var(--bg-2);border-radius:20px;padding:28px;margin-bottom:18px;display:flex;gap:18px;align-items:flex-start}
.cinfo .cblk .ic{width:48px;height:48px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.cinfo .cblk .l{font-size:.78rem;color:var(--slate);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.cinfo .cblk .v{font-size:1.1rem;font-weight:600;margin-top:4px}
.cform{background:#fff;border:1px solid var(--line);border-radius:24px;padding:44px;box-shadow:0 30px 70px -45px rgba(16,23,42,.3)}
.cform label{display:block;font-size:.84rem;font-weight:700;margin:16px 0 7px}
.cform input,.cform textarea,.cform select{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:var(--bg-2);transition:.3s}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--azure);background:#fff}
.form-msg{margin-top:16px;padding:14px;background:#e6f7f1;color:#0a7f63;border-radius:12px;display:none;font-size:.9rem}

/* Policy */
.policy{max-width:820px;margin:0 auto}
.policy h2{font-family:var(--display);font-size:1.6rem;font-weight:700;margin:38px 0 14px}
.policy h3{font-size:1.05rem;font-weight:700;margin:24px 0 10px;color:var(--azure-d)}
.policy p,.policy li{color:var(--ink);margin-bottom:13px;font-size:.97rem}
.policy ul{padding-left:22px}
.policy .updated{color:var(--slate);font-size:.85rem}

/* Cookie */
.cookie{position:fixed;left:24px;right:24px;bottom:24px;z-index:200;background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:26px;box-shadow:0 30px 70px -24px rgba(16,23,42,.4);max-width:960px;margin:0 auto;transform:translateY(200%);transition:.5s cubic-bezier(.2,.8,.2,1)}
.cookie.show{transform:none}
.cookie .ck-ic{font-size:2rem}
.cookie p{font-size:.9rem;color:var(--slate)}
.cookie p a{color:var(--azure);text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie button{padding:11px 22px;border-radius:50px;font-size:.85rem;font-weight:700;cursor:pointer;border:none}
.ck-accept{background:var(--azure);color:#fff}
.ck-decline{background:var(--bg-2);color:var(--ink)}

.reveal{opacity:0;transform:translateY(36px);transition:.85s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:900px){
  .menu{display:none}.burger{display:flex}
  .menu.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;gap:16px}
  .hero-grid{grid-template-columns:1fr;gap:40px}.hero-visual .main-img img{height:380px}
  .hero-float.f1{left:0}.hero-float.f2{right:0}
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .bcard.big,.bcard.coral,.bcard.wide{grid-column:span 2}.bcard.big{grid-row:span 1}
  .feature{grid-template-columns:1fr;gap:30px}
  .stats,.vals,.team,.tcards{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .pad{padding:64px 0}
  .cta{padding:50px 28px}
  .cookie{flex-direction:column;text-align:center}
}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}.bento{grid-template-columns:1fr}.bcard.big,.bcard.coral,.bcard.wide{grid-column:span 1}}
